自定义View绘制文字

第一次写文章难免会有很多不足之处,敬请谅解。


估计很多没怎么写过自定义View的小伙伴在绘制文字的时候总是感到迷茫(What Fuck),为什么怎么绘制文字都是有很大的偏差,其实大家如果查看过API文档的话就可以发现一点:


应该能够注意到绘制文字的居然不是坐标是这两个什么鬼,。(英语不咋地,但也差不多能看懂),也就是说绘制文字时指定的中心点坐标并不是实际绘制之时文字现实的位置,绘制的文字依据baslines的坐标来进行显示,想要了解这两个参数的可以自行百度。现在进入重点绘制文字居中的两种方式:

1,直接绘制


float centerX = paddingLeft + width / 2;
float centerY = paddingTop + height / 2;
Paint.FontMetrics fontMetrics = mTextPaint.getFontMetrics();
float baseLine = -(fontMetrics.ascent + fontMetrics.descent) / 2;
float textWidth = mTextPaint.measureText(hText);
float startX = centerX - textWidth / 2;
float endY = centerY + baseLine;
canvas.drawText(hText, startX, endY, mTextPaint);

2,利用矩Rect绘制

  int);



实际测试两种发可以实现绘制文字居中显示,如果有问题的话欢迎留言。


最后加一点小知识,你说如果我们想要文字垂直居中显示咋办呢,额,泥奏凯,


StaticLayout很熟悉吧,就是在我们输入文字是换行所需要的API。



通过StaticLayout来实现换行居中显示,实测可以实现,希望能给与大家一些帮助,欢迎留言。






  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值