Android自定义控件开发入门与实战(8)Paint基础(1)

构造函数

canvas.drawText(String str,float x,float y,Paint paint);

其中str为文本内容,paint为画笔,x、y为绘制的起点坐标。

起点坐标是文本内容的左下角,y代表的是基线的纵坐标

我们来绘制一个View,然后把基线也绘制出来:

在这里插入图片描述

结论:

  • drawText()函数中y坐标是基线的位置

paint.setTextAlign函数

该函数之前接触过,就是用来表示文本内容在x坐标的左侧、中间、还是右侧

构造函数为:

Paint::setTextAlign(Align align);

//取值为:

paint.setTextAlign(Paint.Align.LEFT); //文本在x坐标右侧

paint.setTextAlign(Paint.Align.CENTER); //文本在x坐标中间

paint.setTextAlign(Paint.Align.RIGHT); //文本在x坐标左侧

所以也知道默认情况下是Paint.Align.LEFT

四线格

除了基线以外,Androdi还提供了额外四个参考线:

  • ascent:单个字符应当的最高高度所在的线(系统推荐)

  • descent:单个字符应当的最低高度所在的线(系统推荐)

  • top:可绘制的最高高度所在线

  • bottom:可绘制的最低高度所在线

关于这部分知识可以上网找图,这里的主要意思是我们在绘制文字的时候,文字的最高高度要尽可能的比ascent要低,而最低高度要比descent要高。并且top要比ascent高,bottom要比descent要低。

FontMetrics

Android提供了一个类FontMetrics用来计算上述的四线格每个属性的值。

他们的计算方法如下:

  • ascent = ascent线的y坐标 - baseline线的y坐标

  • descent = descent线的y坐标 - baseline线的y坐标

  • top = top线的y坐标 - baseline线的y坐标

  • bottom = bottom线的y坐标 - baseline线的y坐标

因为x y轴以文字左下角为原点向右向下,所以ascent为负数,descent为正数。

注:这些值是真实存在的,不要混淆,它们就是用来计算文字的四线格的。

那么如何去获取这四线格涅:

Paint paint = new Paint();

Paint.FontMetrics fm = paint.getFontMetrics();

Paint.FontMetricsInt fmInt = paint.getFontMetricsInt();

这里看到有一个FontMetricsInt类,其实它和FontMetrics类一模一样,只是FontMetrics的值为float型,而FontMetricsInt的值为int型而已。

那么实例fm中就有ascent、descent这些参数啦。

一些常用函数

在这部分我们将学习如何获取字符串所占区域高度、宽度和最小矩形。

1、求一个Text的绘制区域大小,就是直接用bottom线所在的位置来减去top线所在的位置就能得出高度

int top = baseLineY + fmInt.top;

int bottom = baseLineY + fmInt.bottom;

int hegiht = bottom - top;

而宽度也好测量:

int width = paint.measureText(str);

这样就能得到字符串所占区域的高度和宽度辽

2、如何测最小矩形:

最小矩形就是通过系统函数来获取的:

/**

  • Return in bounds (allocated by the caller) the smallest rectangle that

  • encloses all of the characters, with an implied origin at (0,0).

  • 获取指定字符串所对应的的最小矩形,以(0,0)点所在位置为基线。

  • @param text 要测量最小矩形的字符

  • @param start 所要测量字符在字符串中的索引

  • @param end 所要测量的字符串的长度

  • @param bounds 接受测量结果

*/

public void getTextBounds(String text, int start, int end, Rect bounds);

Paint常用函数


这里接hencoder学习自定义view(1)

还有几个函数:

//线帽

setStrokeCap(Paint.Cap cap);

设置线帽有三个参数:Cap.ROUND(圆形线帽) Cap.SQUARE(方形线帽) Cap.BUTT(无线帽)

//设置路径的转角样式

setStrokeJoin(Paint.Join join);

设置转角路径有三个参数:Join.MITER(结合处为锐角) Join.ROUND(结合处为圆弧) Join.BEVEL(结合处为直线)

//抗抖动效果

setDither(bool dither)

什么是抗抖动效果呢?就是因为在RGB模式下 只能显示2^16=65535种颜色,因此很多丰富的色彩变化无法呈现。所以,图像在颜色渐变时,可能会出现大块马赛克的效果。

Android为了让色彩过渡不那么僵硬,于是在变化时的相邻像素颜色取中间值进行“调和”。

//设置是否为粗体文字

setFakeBoldText(boolean fakeBoldText)

//设置带有删除线效果

setStrikeThruText(boolean strikeThruText)

//设置下划线

setUnderlinText(boolean underlineText)

//设置开始绘图点位置

写在最后

由于本文罗列的知识点是根据我自身总结出来的,并且由于本人水平有限,无法全部提及,欢迎大神们能补充~

将来我会对上面的知识点一个一个深入学习,也希望有童鞋跟我一起学习,一起进阶。

提升架构认知不是一蹴而就的,它离不开刻意学习和思考。

**这里,笔者分享一份从架构哲学的层面来剖析的视频及资料分享给大家,**梳理了多年的架构经验,筹备近1个月最新录制的,相信这份视频能给你带来不一样的启发、收获。

最近还在整理并复习一些Android基础知识点,有问题希望大家够指出,谢谢。

希望读到这的您能转发分享和关注一下我,以后还会更新技术干货,谢谢您的支持!

转发+点赞+关注,第一时间获取最新知识点

Android架构师之路很漫长,一起共勉吧!

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

和关注一下我,以后还会更新技术干货,谢谢您的支持!

转发+点赞+关注,第一时间获取最新知识点

Android架构师之路很漫长,一起共勉吧!

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值