自定义View: 在View中居中绘制文字



package com.hzy.tvmao.view.widget;

import com.hzy.tvmao.utils.ui.ViewUtil;

import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Paint.FontMetricsInt;
import android.graphics.Rect;
import android.text.TextUtils;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.widget.ImageView;

public class TouchImageView extends ImageView
{
    private String mText;
    private int mTextSize = ViewUtil.dip2px(13);
    
    public TouchImageView(Context context) {
        super(context);
    }
    
    public TouchImageView(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
    }
    
    public TouchImageView(Context context, AttributeSet attrs) {
        super(context, attrs);
    }
    
    @Override
    public boolean onTouchEvent(MotionEvent event) {
        return super.onTouchEvent(event);
    }
    
    public void setText(String mText) {
        this.mText = mText;
        postInvalidate();
    }
    
    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);
        if (TextUtils.isEmpty(mText)) {
            return;
        }
        Paint mPaint = new Paint(Paint.ANTI_ALIAS_FLAG);
        Rect mBounds = new Rect();
        mPaint.setColor(Color.WHITE);
        mPaint.setTextSize(mTextSize);
        mPaint.getTextBounds(mText, 0, mText.length(), mBounds);
        float textWidth = mBounds.width();
        FontMetricsInt fontMetrics = mPaint.getFontMetricsInt();
        float fontHeight = fontMetrics.bottom - fontMetrics.top;
        //设置文字居中 
        float textBaseY = getHeight() - (getHeight() - fontHeight) / 2 - fontMetrics.bottom;
        canvas.drawText(mText, (getWidth() - textWidth) / 2, textBaseY, mPaint);
        // canvas.drawText(mText, (getWidth() - textWidth) / 2, getHeight(), mPaint);错误的, 不能居中!
        
    }
}


参考 

http://blog.csdn.net/hursing/article/details/18703599 

http://blog.sina.com.cn/s/blog_54254a840101be27.html

转载于:https://my.oschina.net/sfshine/blog/484760

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值