HTML5中Canvas的drawText对齐细节

在HTML5的Canvas中,使用drawText进行文字绘制时,'x'和'y'坐标表示文字的中心。默认对齐方式为左下角,通过设置textAlign和textBaseline属性可以调整文字的水平和垂直对齐,例如将它们设置为'center'和'middle'则实现居中对齐。理解这些细节对于正确绘制文字至关重要。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近接触的项目中,UI纯Html5,这可苦了我这个习惯Android native控件的程序员,其中画字对齐的细节部分困扰我很久。Anyway,总算是搞定

context对象可以设置以下 text 属性:

font:文字字体,同 CSSfont-family 属性


textAlign:文字水平对齐方式。可取属性值: start, end, left,right, center。默认值:start.


textBaseline:文字竖直对齐方式。可取属性值:top, hanging, middle,alphabetic, ideographic, bottom。默认值:alphabetic

有两个方法可以绘制文字: fillText和 strokeText。第一个绘制带 fillStyle 填充的文字,后者绘制只有 strokeStyle 边框的文字。两者的参数相同:要绘制的文字和文字的位置(x,y) 坐标。还有一个可选选项——最大宽度。如果需要的话,浏览器会缩减文字以让它适应指定宽度。


文字对齐属性影响文字与设置的(x,y) 坐标的相对位置。

比如说,


                this.drawContext.textAlign = "center";
           this.drawContext.textBaseline = "middle";

之后,drawText 中的x和y,代表着字的整体中心,而这两个对齐,是以这个x,y点坐标对齐。这一点极容易搞错!

同样的,默认对齐方式,是左下角对齐,也就是说,和普通的盒式布局的坐标不同,默认的drawText坐标,是从左下角算的,而非左上角!


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值