python显示html内容自动换行_canvas绘制文本内容自动换行

原型要求:

要求制作一个邀请卡页面,其中标题字数是动态的,最多可显示2行,如果超出2行则第2行内容结尾添加省略号。根据产品妹子的性格,四行这个设置到时很大机会改,所以这里一定不能写死,结果前几天真的要求改成了最多可显示4行 ,其他照旧。产品妹子too young :)!

废话不说,下面贴代码,献丑了!上代码之前先看一下需要传的参数!!

图文并茂的参数说明,原谅我捉急的PS技术和设计

ctx: 画布的上下文环境

content: 需要绘制的文本内容

drawX: 绘制文本的x坐标

drawY: 绘制文本的y坐标

lineHeight:文本之间的行高

lineMaxWidth:每行文本的最大宽度

lineNum:最多绘制的行数

// 文字自动换行

function textPrewrap(ctx, content, drawX, drawY, lineHeight, lineMaxWidth, lineNum) {

var drawTxt = ''; // 当前绘制的内容

var drawLine = 1; // 第几行开始绘制

var drawIndex = 0; // 当前绘制内容的索引

// 判断内容是否可以一行绘制完毕

if(ctx.measureText(content).width <= lineMaxWidth) {

ctx.fillText(content.substring(drawIndex, i), drawX, drawY);

} else {

for (var i = 0; i < content.length; i++) {

drawTxt += content[i];

if (ctx.measureText(drawTxt).width >= lineMaxWidth) {

if (drawLine >= lineNum) {

ctx.fillText(content.substring(drawIndex, i) + '..', drawX, drawY);

break;

} else {

ctx.fillText(content.substring(drawIndex, i + 1), drawX, drawY);

drawIndex = i + 1;

drawLine += 1;

drawY += lineHeight;

drawTxt = '';

}

} else {

// 内容绘制完毕,但是剩下的内容宽度不到lineMaxWidth

if (i === content.length - 1) {

ctx.fillText(content.substring(drawIndex), drawX, drawY);

}

}

}

}

}

意外发现

在绘制文字的过程中发现,绘制文字的y坐标是不是以文字上方做标准,一图胜多言,上图!

浏览器环境: chrome 71.0.3578.98(正式版本)(64 位)

字体大小为40px

绘制的y坐标为0时,可以看到文本再左上角只漏了一点点出来

绘制的y坐标为40时,可以看到文本可以完全显示

后记

这是一个比较冷门的代码效果,但是也希望可以帮到有需要的朋友

如有帮助的请轻轻点下一个赞表示鼓励!谢谢 :)

如果看到这里首先很感谢花费您一些宝贵的时间看到这里,如有错误的地方希望各位大佬指出错误,谢谢:)

关闭手机闹钟,睡了!明天起来看 雷马大战 !哦吼

2019 coding and basketball!

要实现带下划线的自动换行文本,您可以使用 `StaticLayout` 类。这个类可以帮助您实现多行文本绘制,并且可以根据文本内容中包含的特定字符来添加下划线。下面是一个示例代码: ```java TextPaint textPaint = new TextPaint(); textPaint.setTextSize(50); String text = "1234567890"; float x = 100; float y = 200; int width = 500; // 文本宽度限制,超过这个宽度会自动换行 StaticLayout staticLayout = new StaticLayout(text, textPaint, width, Layout.Alignment.ALIGN_NORMAL, 1.0f, 0.0f, false); canvas.save(); canvas.translate(x, y); staticLayout.draw(canvas); canvas.restore(); // 添加下划线 for (int i = 0; i < text.length(); i++) { char c = text.charAt(i); if (c == '0' || c == '6' || c == '9') { int lineStart = staticLayout.getLineForOffset(i); int lineEnd = staticLayout.getLineForOffset(i + 1); float startX = staticLayout.getLineLeft(lineStart) + x; float endX = staticLayout.getLineRight(lineEnd) + x; float underlineY = y + staticLayout.getLineBaseline(lineStart) + textPaint.getFontMetrics().descent; canvas.drawLine(startX, underlineY, endX, underlineY, textPaint); } } ``` 在这个示例中,我们首先创建一个 `TextPaint` 对象,并设置文字大小为 50。然后,我们定义要绘制文本内容和位置,以及文本的宽度限制。接下来,我们创建一个 `StaticLayout` 对象,通过传入文本、`TextPaint` 对象、宽度限制等参数来构建多行文本布局,并在画布上绘制出来。 最后,我们遍历文本中的每个字符,如果字符是 '0'、'6' 或 '9',则根据字符所在的行信息,获取下划线的起始位置和结束位置,并使用 `canvas.drawLine` 方法绘制下划线。 请注意,这只是一个示例代码,您可以根据实际需求进行修改和优化。希望对您有所帮助!如果还有其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值