在安卓高版本,默认是有下划线的,其默认下划线的颜色是由其主题颜色来控制的!
控制如下:
1
2
3
4
5
|
< style name = "AppTheme" parent = "Theme.AppCompat.Light.DarkActionBar" > <!-- Customize your theme here. --> < item name = "colorPrimary" >@color/colorPrimary</ item > < item name = "colorPrimaryDark" >@color/colorPrimaryDark</ item > **< item name = "colorAccent" >@color/colorPrimaryDark</ item >** |
所以,只需要修改colorAccent的颜色,其下划线的颜色既可以修改!
在低版本和高版本中,同样是可以去添加下划线的!方法有二:
方法一:
1
2
3
4
5
6
7
|
//此时必须要设置其背景为空 < EditText android:background = "@null" android:drawableBottom = "@drawable/line" android:hint = "请输入您的手机号码" android:layout_width = "match_parent" android:layout_height = "wrap_content" /> |
1
2
3
4
5
6
7
|
//资源名称为 drawable/line < shape xmlns:android = "http://schemas.android.com/apk/res/android" > < solid android:color = "@color/colorBlue" /> < size android:height = "1dp" android:width = "1000dp" /> </ shape > |
方法二:通过自定义editText
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
public class UnderLineEditText extends EditText { private Paint paint; public UnderLineEditText(Context context, AttributeSet attrs) { super (context, attrs); //设置画笔的属性 paint = new Paint(); paint.setStyle(Paint.Style.STROKE); //设置画笔颜色为红色 paint.setColor(Color.RED); } @Override protected void onDraw(Canvas canvas) { super .onDraw(canvas); /**canvas画直线,从左下角到右下角,this.getHeight()-2是获得父edittext的高度,但是必须要-2这样才能保证 * 画的横线在edittext上面,和原来的下划线的重合 */ canvas.drawLine( 0 , this .getHeight()- 2 , this .getWidth()- 2 , this .getHeight()- 2 , paint); } } |
这里有几点需要注意:
其一:也可以继承android.support.v7.widget.AppCompatEditText,但是有时会出现获取不到焦点的现状
其二:下划线的的位置确定
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://www.cnblogs.com/zhujiabin/p/9530789.html