Baseline是文字绘制时所参照的基准线,只有先确定了Baseline的位置,我们才能准确的将文字绘制在我们想要的位置上。Baseline的概念在我们使用TextView等系统控件直接设置文字内容时是用不到的,但是如果我们想要在Canvas画布上面绘制
文字时,Baseline的概念就必不可少了。

我们先了解一下Android中Canvas画布绘制文字的方法,如下图:

参数示意:

  • text,文字内容

  • x,文字从画布上开始绘制的x坐标(Canvas是一个原点在左上角的平面坐标系)

  • y,Baseline所在的y坐标,不少人已开始以为y是绘制文字区域的底部坐标,其实是不正确的,这是两个概念

  • paint,画笔,设置的文字的大小颜色等属性

  • 了解了文字绘制的方法,我们现在就了解一下这个参数y(Baseline)的计算方法。

Baseline的概念

我们先看一行文字各区域的分布示意图

从上图来看,Baseline不难理解,它就是E和h的下边界线。我们还可以得出一个结论,文字的高度=Descent+Ascent。

然而,上面这个公式并不完全准确,我们再看一个图:

我们看到,如果文字的上方有一些特殊的符号,比如上图中的~或者是我们汉语拼音中的声调时,文字区域又会多出一部分Leading。

因此,完整的公式应该是

文字的高度=Descent+Ascent+Leading。

那么,为什么第一幅图中没有说明Leading的存在呢,原因是我们通常在绘制一行英文或者中文时,Leading的高度为0。我们看一个证据图,下图是在绘制英文文字时调试取得的数据。

其中leading=0,所以我们在文字绘制时不需要考虑Leading,图中的数值都是距离Baseline的距离,在Baseline上方为负值,下方为正值。

Baseline位置(y轴坐标)的计算

为了方便我们对计算过程进行理解,我画了一幅帮助图,如下:

假设我们是在画布Canvas的顶部绘制一行文字,规定一行文字的高度是y,文字区域的高度是Height(TOP和BOTTOM之间,TOP到0和BOTTOM到y的距离相等,这样文字才看起来是居中)。因此,0到y和TOP到BOTTOM的中线是重合的,y轴坐标都是y/2。

BOTTOM之间,TOP到0和BOTTOM到y的距离相等,这样文字才看起来是居中)。因此,0到y和TOP到BOTTOM的中线是重合的,y轴坐标都是y/2。

Android文字基线Baseline算法的使用讲解,小码农也有大梦想相关推荐

  1. 小码农也有大梦想!最小公倍数java算法

    学习内容大致内容: 1.架构师筑基(Linux基础与进阶+Netty框架+Mysql+并发编程+JVM性能调优+Tomcat) 2.开源框架(主要涉及SSM框架) 3.高性能架构(Mysql高性能存储 ...

  2. Android版数据结构与算法(五):LinkedHashMap核心源码彻底分析

    版权声明:本文出自汪磊的博客,未经作者允许禁止转载. 上一篇基于哈希表实现HashMap核心源码彻底分析 分析了HashMap的源码,主要分析了扩容机制,如果感兴趣的可以去看看,扩容机制那几行最难懂的 ...

  3. 算法给小码农八大排序 八奇计只为宝儿姐

    文章目录 八排 八奇迹 排序 排序的概念及其运用 排序的概念 排序运用 ==来上京东== ==大学排名== 常见的排序算法 常见排序算法的实现 插入排序 基本思想 ==但是数组肯定不是有序的,所以我们 ...

  4. 算法给小码农冒泡排序铭纹,快速排序四极

    文章目录 排序 常见的排序算法 常见排序算法的实现 冒泡排序 ==也是我们本身接触最早的排序 很简单的一个排序== 完整冒泡排序代码 快速排序(无敌的排序) 将区间按照基准值划分为左右两半部分的常见方 ...

  5. 算法给小码农堆魂器--铁血柔情

    文章目录 堆 堆的概念及结构 堆的性质 堆的结构(这里实现大堆) 堆的结构体 堆初始化函数HeapInit 堆销毁函数HeapDestroy 堆打印函数HeapPrint 向上调整函数AdjustUp ...

  6. Android版数据结构与算法汇总十二章

    Android版数据结构与算法(一):基础简介 https://www.cnblogs.com/leipDao/p/9140726.html Android版数据结构与算法(二):基于数组的实现Arr ...

  7. Android 文字测量

    Android 文字测量 获取文字长度: 方式1,只获取文字绘制的长度 var textValue = "待测量文字" var txtLength = mPaint.measure ...

  8. 优化算法求解复杂约束问题策略(以粒子群算法为例讲解求解复杂约束问题的多种策略)

    优化算法求解复杂约束问题策略(以粒子群算法为例讲解求解复杂约束问题的多种策略)python实现     整个代码文字讲解共17页 提示:专栏解锁后,可以查看该专栏所有文章. 文章目录 策略1:在位置更 ...

  9. 【Applied Algebra】求解布尔方程(Boolean Equations)的4个高效baseline算法

    求解布尔方程(Boolean Equations)的4个高效baseline算法 求解布尔方程(Boolean Equations)是理论计算机中的基本问题之一;事实上,求解Fq\mathbb{F}_ ...

最新文章

  1. 使用alterMIME实现添加message footer功能
  2. 架构师的第一阶段:准备做(Pre-Architecture)
  3. 图灵LAMP类图书精彩荟萃
  4. 认识ASP.NET配置文件Web.config
  5. 对比学习系列论文SimROD(二): A Simple Adaptation Method for Robust Object Detection
  6. 二、WPF datagrid 特定行变色
  7. java arm 编译器下载_最全盘点:18款在线C/C++/Py/Java编译器,一个比一个强大(附地址)...
  8. 【计算机网络复习 数据链路层】3.1 数据链路层功能概述
  9. 华为智能计算发布FusionServer Pro智能服务器
  10. OpenShift 4 - 通过 REST API 操作 OpenShift
  11. Linux---线程池的实现
  12. sprintf函数、snprintf函数、asprintf函数、vsprintf
  13. Jsp简单入门与Jsp实用教程总结
  14. 微信网页支付小白指南-域内浏览器支付 + 外部浏览器支付
  15. 一图掌握ICT项目管理流程图【实例】
  16. logo计算机编程简单指令,完整版PCLOGO编程技巧
  17. 页面置换算法之最佳置换算法的模拟(C++)
  18. 国防科技大学计算机考研资料汇总
  19. BZOJ 1812 IOI 2005 riv
  20. 一个字符串“0”,竟是B站崩溃的元凶...

热门文章

  1. 【FPGA教程案例34】通信案例4——基于FPGA的QPSK调制信号产生,通过matlab测试其星座图
  2. vue 关闭 窗口后清除所有数据_Vue首屏加载速度优化,我用这几个技巧提升80%以上...
  3. miracast和乐播投屏_手机投屏到电视的5种方法 看完才知道原来这么简单!
  4. 中企动力是怎么样的公司
  5. 软件工程基础知识--软件过程模型
  6. 双向搜索算法(基于深度优先搜索算法的优化)
  7. linux添加新字体
  8. 【MySQL】把成绩低于总平均成绩的女同学的的成绩提高5%
  9. 一篇文章让你轻松通过佛科院的电子线路CAD考试——Altium Designer 14原理图设计与PCB设计(叶林朋著)
  10. 离散制造业数字化转型实践分享