android测量控件高度,Android中测量控件的内部文字内容的宽、高度

Android中,在自定义View中通过Canvas绘制文字时,需要测量控件的内部文字内容的宽、高度。这里记录下几种比较常用的方法,仅作备忘。

Paint.measureText (测量文本的宽度)

Paint paint = new Paint();

paint.setTextSize(size);

float strWidth = paint.measureText(str);

Paint.getTextBounds (获得文字所在矩形区域,可以得到宽高)

Paint paint = new Paint();

Rect rect = new Rect();

paint.getTextBounds(str, 0, str.length(), rect);

int w = rect.width();

int h = rect.height();

Paint.getTextWidths(获得每个字符的宽度)

float width = 0;int len = str.length();

Paint paint = new Paint();

float[] widths = new float[len];

paint.getTextWidths(str, widths);

for (int i = 0; i < len; i++) {

width += widths[i];

}

通过Paint.FontMetrics or Paint.FontMetricsInt来获取高度

这两者的含义相同,只不过精度不同,一个float、一个int。

Paint paint = new Paint();

paint.setTextSize(size);//设置字体大小

paint.setTypeface(Typeface.xx);//设置字体

FontMetrics fontMetrics = getFontMetrics();

float height1 = fontMetrics.descent - fontMetrics.ascent;

float height2 = fontMetrics.bottom - fontMetrics.top;

这里获取的两个高度略有不同,height2的高度会略大于height1,这样在文本的顶部和底部就会有一些留白。具体使用哪个高度,要看具体需求了。

此外,还可以通过Paint.getFontSpacing和Paint.getFontMetrics(null)来获得高度,其实前者也是调用后者来实现的。这里的值和通过fontMetrics.descent - fontMetrics.ascent获得的大小是一致的。

Layout.getDesiredWidth (获得宽度)

TextPaint textPaint = new TextPaint();

paint.setTextSize(size);//设置字体大小

paint.setTypeface(Typeface.xx);//设置字体

float width = Layout.getDesiredWidth(str,textPaint);

之前碰到一个问题,TextView在布局上占用的高度和属性textSize的大小不一样,要比textSize的值大一些(比如textSize=”12dp”,实际的高度大概有14-16dp),仔细看的话会发现文字的上方和下发留有空白。查了下文档,发现可以通过设置android:includeFontPadding来控制是否包含上下空白。

参考图:

1408acdbace4

Paste_Image.png

特别说明:

基准点是Baseline

FontMetricInt.ascent是Baseline之上至字符最高处的距离

FontMetricInt.descent是Baseline之下至字符最低处的距离

Leading文档说的很含糊,其实是上一行字符的descent到下一行的ascent之间的距离

r.top指的是指的是最高字符到Baseline的值,即ascent的最大值

同上,r.bottom指的是最下字符到Baseline的值,即descent的最大值

FontMetricInt.top和 FontMetricInt.bottom是控件的顶部和底部位置

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值