首页 > 代码库 > Android自己定义视图(一):带下划线的TextView
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); } }
加入布局文件:
<com.francis.underlinetextviewtest.UnderlineTextView android:text="@string/hello_world" android:layout_width="wrap_content" android:layout_height="wrap_content" android:textStyle="bold" android:textColor="#FFDDDDDD"/>
Android自己定义视图(一):带下划线的TextView
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。