Android: 绘制的文本如何排版

项目需求,在一个特定的矩形内绘制一段文本,并且要让文本处于矩形的正中间。


原来的方法:

先设置paint颜色,字体,字体大小等等

paint.setColor(Color.WHITE);
paint.setTextSize(fontSize);


Path textPath = new Path();

textPath.moveTo(rect_x1,textPontY);
textPath.cubicTo(rect_x1,textPontY, rect_x1,textPontY, rect_x1+rect_width,textPontY);
paint.setTextAlign(Paint.Align.CENTER);
canvas.drawTextOnPath(mailBox.getBoxNumber(), textPath, 0, 0, paint);


关键在于这个 textPontY的值如何确定。如果定位不准,达到的效果就是在水平方向上它是居中的(3点一线),在垂直方向并不是


后来想到,通过path来设置,让path沿着一个封闭的矩形,如下:

Path textPath = new Path();
textPath.moveTo(rect_x1,rect_y1);
textPath.lineTo(rect_x1 + rect_width, rect_y1);
textPath.lineTo(rect_x1 + rect_width, rect_y1+rect_height);
textPath.lineTo(rect_x1 , rect_y1+rect_height);
textPath.lineTo(rect_x1,rect_y1);
textPath.close();

然后设置 paint.setTextAlign(Paint.Align.CENTER); ,然后再 canvas.drawTextOnPath(mailBox.getBoxNumber(), textPath, 0, 0, paint);

结果证明这个想法是错误的,它并不能智能定位到矩形正中间的位置



如何 textPontY的值如何确定 ?涉及到 “android字体大小对应的高度”


下文来自: http://www.iteye.com/topic/474526

Canvas 作为绘制文本时,使用FontMetrics对象,计算位置的坐标

它的思路和java.awt.FontMetrics的基本相同。

FontMetrics对象

它以四个基本坐标为基准,分别为:

・FontMetrics.top
・FontMetrics.ascent
・FontMetrics.descent
・FontMetrics.bottom

该图片将如下

Java代码 收藏代码
  1. PainttextPaint=newPaint(Paint.ANTI_ALIAS_FLAG);
  2. textPaint.setTextSize(35);
  3. textPaint.setColor(Color.WHITE);
  4. //FontMetrics对象
  5. FontMetricsfontMetrics=textPaint.getFontMetrics();
  6. Stringtext="abcdefghijklmnopqrstu";
  7. //计算每一个坐标
  8. floatbaseX=0;
  9. floatbaseY=100;
  10. floattopY=baseY+fontMetrics.top;
  11. floatascentY=baseY+fontMetrics.ascent;
  12. floatdescentY=baseY+fontMetrics.descent;
  13. floatbottomY=baseY+fontMetrics.bottom;
  14. //绘制文本
  15. canvas.drawText(text,baseX,baseY,textPaint);
  16. //BaseLine描画
  17. PaintbaseLinePaint=newPaint(Paint.ANTI_ALIAS_FLAG);>
  18. baseLinePaint.setColor(Color.RED);
  19. canvas.drawLine(0,baseY,getWidth(),baseY,baseLinePaint);
  20. //Base描画
  21. canvas.drawCircle(baseX,baseY,5,baseLinePaint);
  22. //TopLine描画
  23. PainttopLinePaint=newPaint(Paint.ANTI_ALIAS_FLAG);
  24. topLinePaint.setColor(Color.LTGRAY);
  25. canvas.drawLine(0,topY,getWidth(),topY,topLinePaint);
  26. //AscentLine描画
  27. PaintascentLinePaint=newPaint(Paint.ANTI_ALIAS_FLAG);
  28. ascentLinePaint.setColor(Color.GREEN);
  29. canvas.drawLine(0,ascentY,getWidth(),ascentY,ascentLinePaint);
  30. //DescentLine描画
  31. PaintdescentLinePaint=newPaint(Paint.ANTI_ALIAS_FLAG);
  32. descentLinePaint.setColor(Color.YELLOW);
  33. canvas.drawLine(0,descentY,getWidth(),descentY,descentLinePaint);
  34. //ButtomLine描画
  35. PaintbottomLinePaint=newPaint(Paint.ANTI_ALIAS_FLAG);
  36. bottomLinePaint.setColor(Color.MAGENTA);
  37. canvas.drawLine(0,bottomY,getWidth(),bottomY,bottomLinePaint);
-------------------------------------
由上可得出一个常识:drawText绘制文本时,是从baseLine这个位置开始的,并不简单认为是从文本的左下角开始绘制。

由上图可以分析出:

float temp = Math.abs(fontMetrics.top - fontMetrics.bottom);
float textPontY = rect_y1 + (rect_height - temp)/2.0f + temp - fontMetrics.bottom;


把 textPointY设置成这样的值,就对了!


更多相关文章

  1. android:限制文本长度加省略号用ellipsize
  2. 将服务器端字符读取至android的文本控件,换行符变成了黑方块的原
  3. Android复合文本SpannableString使用总结
  4. 《Android Studio实用指南》12.18 文本搜索工具
  5. drawRoundRect方法:绘制圆角矩形
  6. android 各个span类详解--用于富文本的编排 上
  7. Android上实现柱状图表 可实现边框矩形 没填充色
  8. android 获取定位坐标,在百度地图出现大偏移的处理办法

随机推荐

  1. Android(安卓)调试桥(adb)是多种用途的工
  2. Android简明开发教程二十三:发布应用
  3. Android――动画专题研究
  4. Android消息处理机制
  5. layout_weight体验(实现按比例显示)
  6. 聊聊Android(安卓)M 6.0 的运行时权限
  7. Android给view或者布局添加水波纹点击效
  8. Android(安卓)保存 JNI 层 opencv cvMat
  9. Ubuntu上编译Android过程
  10. ANDROID Porting系列九、Lights