Android 定制EditText 改变 底线颜色
2015-08-14 16:42
302 查看
项目需求
最近做 android 项目遇到这个问题,为了保持 app 风格一致,需要将原生的EditText底线颜色改成橙色。网上搜了一些解决方案,特此记录总结一下。效果图
默认的 EditText 底线颜色 是蓝色的,我们 想 实现 橙色的 效果
实现方法
准备两个背景图
一个作为 edittext 的默认背景 , 另一个作为 输入时候的背景Note
使用 9.png, 不要用png, 否则图片会模糊, 花掉
在文件夹 drawable 用selector 建立一个xml 文件
[code]<!-- 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 里 写代码[code]<!-- 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
[code]<!-- 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 去除边框
[code] android:background="@null"
这个代码可以去掉 edittext 的边框
edittext 底部加线
在 drawable 新建一个 line.xml[code]<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 的布局文件中 引用
[code]<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" />
相关文章推荐
- 你还在用notifyDataSetChanged?
- Android笔记(十三) Android中的基本组件——文本
- android adapter 深刻分析
- [Android 4.4.3] 泛泰A870 Mokee4.4.3 20140610 RC2.0 通过刷第三版 by syhost
- ViewDragHelper详解
- Android 长度单位dp , sp ,px总结
- Android开发规范
- 如何能够在Android运行Java的main方法
- Android自定义View画曲线
- Android framework系统默认设置修改
- android linearlayout代替listview实现
- Android中定时器的3种实现方法
- Android国际化
- Android Fragment 你应该知道的一切
- SEAndroid的各种策略文件
- Android Fragment 真正的完全解析(下)
- 【Android应用开发技术:基础构建】命令行下的Android应用开发
- Android FragmentManage FragmentTransaction介绍(三)
- Android Fragment 真正的完全解析(上)
- android apk嵌套 从一个apk启动另外一个apk