最近做 android 项目遇到这个问题,为了保持 app 风格一致,需要将原生的edittext底线颜色改成橙色。网上搜了一些解决方案,特此记录总结一下。
效果图
默认的edittext底线颜色是蓝色的,
我们想实现橙色的效果
实现方法
1、准备两个背景图
一个作为 edittext 的默认背景 , 另一个作为 输入时候的背景
note
使用 9.png, 不要用png, 否则图片会模糊, 花掉
在文件夹 drawable 用selector 建立一个xml 文件
1
2
3
4
5
6
7
|
<!-- drawable/edittext_shape.xml -->
<selector xmlns:android= "http://schemas.android.com/apk/res/android" >
<item android:drawable= "@drawable/edittext_default" android:state_focused= "false" />
<item android:drawable= "@drawable/edittext_focused" android:state_focused= "true" />
</selector>
|
在 values 文件夹 下面的 styles.xml 新建一个style
此步骤是为了复用这个样式, 也可以不用style, 直接在 layout里的布局 xml 里 写代码
1
2
3
4
5
6
7
8
9
10
11
|
<!-- drawable/values/styles.xml -->
<style name= "smsedittext" >
<item name= "android:layout_marginleft" >20dp</item>
<item name= "android:layout_marginright" >20dp</item>
<item name= "android:layout_margintop" >20dp</item>
<item name= "android:layout_width" >match_parent</item>
<item name= "android:layout_height" >wrap_content</item>
<item name= "android:textsize" >16sp</item>
<item name= "android:background" > @drawable /edittext_shape</item>
</style>
|
在layout的布局文件中引用定制的edittext
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
<!-- drawable/layout/fragment_bomb.xml -->
<linearlayout
android:id= "@+id/input"
android:layout_width= "match_parent"
android:layout_height= "match_parent"
android:orientation= "vertical"
android:padding= "20dp" >
<edittext
android:id= "@+id/phone"
style= "@style/smsedittext"
android:hint= "@string/phone_hint"
android:inputtype= "phone"
android:maxlength= "11"
android:maxlines= "1" />
<edittext
android:id= "@+id/times"
style= "@style/smsedittext"
android:hint= "@string/times_hint"
android:inputtype= "number"
android:maxlines= "1" />
</linearlayout>
|
在edittext 底部加上一条直线( 仿微信)
原生的效果是edittext底部是一个凹形的线,这样不是很美观。微信的输入框下面是一条直线。如何实现呢?可以将上面的图片改成直线型的,不过需要美工人员 ps 的帮忙。我们也可以利用 xml 文件来画出图形,完成所需的直线效果。
利用xml 画线
本来想利用xml 画线, 做出微信 输入框 的那种下面是一条直线,发现纯粹用xml不美观, 这种还是让美工做一个背景图可能比较好。
查看这篇文章:android利用xml实现分割线
edittext 去除边框
android:background="@null"
这个代码可以去掉 edittext 的边框
edittext 底部加线
在drawable 新建一个 line.xml
1
2
3
4
5
6
7
8
9
10
|
<shape xmlns:android= "http://schemas.android.com/apk/res/android"
android:shape= "rectangle" >
<solid android:color= "@color/orange_normal" />
<size
android:height= "1dp"
android:width= "1000dp" />
</shape>
|
在layout 的布局文件中引用
1
2
3
4
5
6
7
8
9
10
|
<edittext
android:id= "@+id/phone"
android:layout_width= "match_parent"
android:layout_height= "wrap_content"
android:background= "@null"
android:drawablebottom= "@drawable/line"
android:hint= "@string/phone_hint"
android:inputtype= "phone"
android:maxlength= "11"
android:maxlines= "1" />
|
以上就是本文的全部内容,希望对大家的学习有所帮助。