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

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

  1. Paint.measureText (测量文本的宽度)
Paint paint = new Paint();
paint.setTextSize(size);
float strWidth = paint.measureText(str);
  1. 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();
  1. 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];
}
  1. 通过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获得的大小是一致的。

  1. 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来控制是否包含上下空白。

参考图:


Paste_Image.png

特别说明:

  1. 基准点是Baseline
  2. FontMetricInt.ascent是Baseline之上至字符最高处的距离
  3. FontMetricInt.descent是Baseline之下至字符最低处的距离
  4. Leading文档说的很含糊,其实是上一行字符的descent到下一行的ascent之间的距离
  5. r.top指的是指的是最高字符到Baseline的值,即ascent的最大值
  6. 同上,r.bottom指的是最下字符到Baseline的值,即descent的最大值
  7. FontMetricInt.top和 FontMetricInt.bottom是控件的顶部和底部位置
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352

推荐阅读更多精彩内容

  • 一、概述 1. 四线格与基线 小时候,我们在刚开始学习写字母时,用的本子是四线格的,我们必须把字母按照规则写在四线...
    addapp阅读 7,646评论 2 17
  • @(Android技术文章)个人博客地址: 斯科特安的时间 转载自: Android中测量Text的宽度和高度 A...
    斯科特安阅读 11,236评论 0 10
  • 系列文章之 Android中自定义View(一)系列文章之 Android中自定义View(二)系列文章之 And...
    YoungerDev阅读 2,214评论 0 1
  • 上个世纪的香港影坛美女云集,各具魅力的她们是香港电影中让人惊艳的风景。天然去雕饰的容颜,经典的电影形象,即使经历岁...
    千夜之夜阅读 620评论 2 3
  • 管理小课堂从如何制定目标到目标如何落地,内容紧密相结合。把每个目标先分解,再安排到工作日程中,每天、每周、...
    美丽玲珑阅读 411评论 0 0