`
hyongbai
  • 浏览: 15723 次
文章分类
社区版块
存档分类
最新评论

文字 单元格居中显示 paint ascent descent baseline 文字显示 尺寸 格式

 
阅读更多

基线(baeseline),坡顶(ascenter),坡底(descenter)
上坡度(ascent),下坡度(descent)
行间距(leading):坡底到下一行坡顶的距离
字体的高度=上坡度+下坡度+行间距

ascent是指从一个字的基线(baseline)到最顶部的距离,descent是指一个字的基线到最底部的距离

注意, ascent和top都是负数

下面代码实现高度只有0.75单元格高度的居中显示,所以要下移一定距离y。

foreground.setStyle(Style.FILL);
foreground.setTextSize(height * 0.75f);
foreground.setTextScaleX(width / height);
foreground.setTextAlign(Paint.Align.CENTER);

// Draw the number in the center of the tile
FontMetrics fm = foreground.getFontMetrics();
// Centering in X: use alignment (and X at midpoint)
float x = width / 2;
// Centering in Y: measure ascent/descent first
float y = height / 2 - (fm.ascent + fm.descent) / 2;

网络的例子:(引用http://www.j<wbr>avaeye.com/t<wbr>opic/474526)</wbr></wbr>

package com.TextTest;
import android.app.Activity;
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Paint.FontMetrics;
import android.os.Bundle;
import android.view.View;

public class TextTest extends Activity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
//setContentView(R.layout.main);
setContentView(new GraphView(this));
}

static public class GraphView extends View {
public GraphView(Context context) {
super(context);
}

@Override
protected void onDraw(Canvas canvas) {
//
Paint textPaint = new Paint( Paint.ANTI_ALIAS_FLAG);
textPaint.setTextSize(35);
textPaint.setColor(Color.WHITE);

// FontMetrics对象
FontMetrics fontMetrics = textPaint.getFontMetrics();
String text = "abcdefghijklmnopqrstu";

// 计算每一个坐标
float baseX = 0;
float baseY = 100;
float topY = baseY + fontMetrics.top;
float ascentY = baseY + fontMetrics.ascent;
float descentY = baseY + fontMetrics.descent;
float bottomY = baseY + fontMetrics.bottom;

// 绘制文本
canvas.drawText( text, baseX, baseY, textPaint);

// BaseLine描画
Paint baseLinePaint = new Paint( Paint.ANTI_ALIAS_FLAG);
baseLinePaint.setColor(Color.RED);
canvas.drawLine(0, baseY, getWidth(), baseY, baseLinePaint);

// Base描画
canvas.drawCircle( baseX, baseY, 5, baseLinePaint);

// TopLine描画
Paint topLinePaint = new Paint( Paint.ANTI_ALIAS_FLAG);
topLinePaint.setColor( Color.LTGRAY);
canvas.drawLine(0, topY, getWidth(), topY, topLinePaint);

// AscentLine描画
Paint ascentLinePaint = new Paint( Paint.ANTI_ALIAS_FLAG);
ascentLinePaint.setColor( Color.GREEN);
canvas.drawLine(0, ascentY, getWidth(), ascentY, ascentLinePaint);

// DescentLine描画
Paint descentLinePaint = new Paint( Paint.ANTI_ALIAS_FLAG);
descentLinePaint.setColor( Color.YELLOW);
canvas.drawLine(0, descentY, getWidth(), descentY, descentLinePaint);

// ButtomLine描画
Paint bottomLinePaint = new Paint( Paint.ANTI_ALIAS_FLAG);
bottomLinePaint.setColor( Color.MAGENTA);
canvas.drawLine(0, bottomY, getWidth(), bottomY, bottomLinePaint);
}
}

}

分享到:
评论

相关推荐

    Android文字基线Baseline算法的使用讲解

    Descent是文字底部到Baseline的距离,Ascent是文字顶部到Baseline的距离,而Leading则是行间距,通常在英文或中文中,Leading为0。文字高度的完整公式是:文字高度 = Descent + Ascent + Leading。在没有特殊字符如...

    字体属性及测量(FontMetrics).doc

    首先,FontMetrics 的参数可以分为六类:基准点(baseline)、ascent、descent、leading、top、bottom。基准点是字体的基准线,ascent 是字体的最高点到基准线的距离,descent 是字体的最低点到基准线的距离。...

    Android Canvas的drawText()与文字居中方案详解

    在Android中,我们可以使用`setTextAlign()`方法来改变文字的对齐方式,包括左对齐(`Paint.Align.LEFT`)、居中对齐(`Paint.Align.CENTER`)和右对齐(`Paint.Align.RIGHT`)。不同的对齐方式会影响`x`参数的实际...

    Android Canvas drawText文字居中的一些事(图解)

    FontMetrics 类有五个成员变量:top、ascent、baseline、descent、bottom 和 leading。这些变量的值都代表着不同的坐标位置,例如 top 代表从基线向上绘制区域的最高点,ascent 代表单行文本,从基线向上绘制的推荐...

    Android自定义跑马灯文字效果

    baseline = (canvas.getHeight() - fontMetrics.descent) + fontMetrics.ascent; canvas.drawText(text, drawTextX, baseline, paint); if (isStarting) { drawTextX -= scrollTile; if (drawTextX ) { ...

    Android中FontMetrics的几个属性全面讲解

    总结来说,`FontMetrics`是Android中处理文字绘制时的重要工具,它的属性提供了对字体尺寸和位置的详细描述。通过合理利用这些信息,开发者可以创建出更加精致和用户体验良好的文本展示效果。希望本文能对你在...

    Android使用FontMetrics对象计算位置坐标

    在示例代码中,开发者创建了一个简单的示意图,通过不同颜色的线条描绘了FontMetrics的各个部分,包括基线(BaseLine)、顶部(TopLine)、上升部(AscentLine)、下降部(DescentLine)和底部(ButtomLine)。...

Global site tag (gtag.js) - Google Analytics