android布局矩形只显示一条底线,Android自己定义视图(一):带下划线的TextView...

package com.francis.underlinetextviewtest;

import android.content.Context;

import android.content.res.Resources;

import android.graphics.Canvas;

import android.graphics.Color;

import android.graphics.Paint;

import android.util.AttributeSet;

import android.util.Log;

import android.util.TypedValue;

import android.widget.TextView;

/**

* Created by Francis on 14-10-13.

*/

public class UnderlineTextView extends TextView {

private final Paint mPaint = new Paint();

private int mUnderlineHeight = 0;

public UnderlineTextView(Context context) {

this(context, null);

}

public UnderlineTextView(Context context, AttributeSet attrs) {

this(context, attrs, 0);

}

public UnderlineTextView(Context context, AttributeSet attrs, int defStyle) {

super(context, attrs, defStyle);

init(context, attrs);

}

private void init(Context context, AttributeSet attrs) {

Resources r = getResources();

// mUnderlineHeight == 6

mUnderlineHeight = (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, 2, r.getDisplayMetrics());

}

@Override

public void setPadding(int left, int top, int right, int bottom) {

super.setPadding(left, top, right, bottom + mUnderlineHeight);

}

@Override

protected void onDraw(Canvas canvas) {

super.onDraw(canvas);

// Draw the underline the same color as the text

mPaint.setColor(getTextColors().getDefaultColor());

// 对角线上的两点。

canvas.drawRect(0, getHeight() - mUnderlineHeight, getWidth(), getHeight(), mPaint);

}

}

加入布局文件:

android:text="@string/hello_world"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:textStyle="bold"

android:textColor="#FFDDDDDD"/>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值