【Android 应用开发】Canvas 精准绘制文字 ( 文本边界坐标解析 | 绘图位置 )

2023-03-29 21:05:27 浏览数 (2)

文章目录

  • 一、文本边界坐标解析
  • 二、绘图位置

一、文本边界坐标解析


在上一篇博客 【Android 应用开发】Canvas 精准绘制文字 ( 测量文本真实边界 | 将文本中心点与给定中心点对齐 ) 中 , 简要介绍了 Paint.getTextBounds() 函数获取的 Rect 边界 , 今天补充下精准的绘图信息 ;

Rect 中获取的坐标值示例 : left = 4 , top = -31 , right = 28 , bottom = 0 ;

上述坐标是相对于 下图中的 (0, 0) 原点坐标系的值 ;

下图中的原点位置 , 就是调用 Canvas 的 drawText 方法 , 传入的 x 值和 基线值 ;

下图中的 绿色矩形框是 Canvas 的绘图区域 , 橙色矩形框是 Canvas 绘制的文本的实际区域 ;

绘图区域 包含 文本实际占用区域 ;

上述的坐标值 , 是在如下坐标系的值 ;

代码语言:javascript复制
left = 4 , top = -31 , right = 28 , bottom = 0 ; 

left 值是 绘图区域 最左侧 距离 文本实际区域 的左侧这段空隙的宽度 ;

right 值是 绘图区域 最左侧 距离 文本实际区域 的右侧这段空隙的宽度 ;

可以得到 文本区域 的中心值 , 距离 绘图区域 的值为

rm cfrac{left right}{2}

;

top 值是 基线值 - 基线距离文本顶部的值 , 基线值是 0 , 一般都是负数 , 这里是 -31 ;

botttom 值是 基线距离文本底部值 - 基线值 , 基线值是 0 , 正数 , 负数 , 0 都有可能 , 这里是 0 ; 一般是正数或 0 , 负数不常见 ;

二、绘图位置


使用 Canvas 的 drawText 方法绘制文字 , 传入 ( x , y ) 坐标 , x 是绘制区域的左侧 , y 是文本基线 , 绘制的位置如下 :

如果不是要求很精确的话 , 一定程度上可以理解为 传入的值 左下角的位置 ;

如果要精准到像素级别 , 保证1个像素都不差 , 就要考虑到 绘图区域 中 文本区域 的范围 ;

进行精确的计算 ;

0 人点赞