android 颜色自动变淡,Android定制自己的EditText轻松改变底线颜色

最近做 android 项目遇到这个问题,为了保持 app 风格一致,需要将原生的EditText底线颜色改成橙色。网上搜了一些解决方案,特此记录总结一下。

效果图

默认的EditText底线颜色是蓝色的,

76b298714629b96ef92c3eafd6aaa6c6.png

我们想实现橙色的效果

0b23700edde2bb9405653a9953d72651.png

实现方法

1、准备两个背景图

一个作为 edittext 的默认背景 , 另一个作为 输入时候的背景

Note

使用 9.png, 不要用png, 否则图片会模糊, 花掉

1429d99023f8f82df1488a37362d47e8.png

在文件夹 drawable 用selector 建立一个xml 文件

在 values 文件夹 下面的 styles.xml 新建一个style

此步骤是为了复用这个样式, 也可以不用style, 直接在 layout里的布局 xml 里 写代码

20dp

20dp

20dp

match_parent

wrap_content

16sp

@drawable/edittext_shape

在layout的布局文件中引用定制的edittext

android:id="@+id/input"

android:layout_width="match_parent"

android:layout_height="match_parent"

android:orientation="vertical"

android:padding="20dp" >

android:id="@+id/phone"

style="@style/SmsEditText"

android:hint="@string/phone_hint"

android:inputType="phone"

android:maxLength="11"

android:maxLines="1" />

android:id="@+id/times"

style="@style/SmsEditText"

android:hint="@string/times_hint"

android:inputType="number"

android:maxLines="1" />

在edittext 底部加上一条直线( 仿微信)

原生的效果是edittext底部是一个凹形的线,这样不是很美观。微信的输入框下面是一条直线。如何实现呢?可以将上面的图片改成直线型的,不过需要美工人员 PS 的帮忙。我们也可以利用 xml 文件来画出图形,完成所需的直线效果。

04cdb3e4c9f98a86b7f97c20a327760c.png

利用xml 画线

本来想利用xml 画线, 做出微信 输入框 的那种下面是一条直线,发现纯粹用xml不美观, 这种还是让美工做一个背景图可能比较好。

edittext 去除边框

android:background="@null"

这个代码可以去掉 edittext 的边框

edittext 底部加线

在drawable 新建一个 line.xml

android:shape="rectangle" >

android:height="1dp"

android:width="1000dp" />

在layout 的布局文件中引用

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" />

以上就是本文的全部内容,希望对大家的学习有所帮助。

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值