步骤如下

1:实现自定义控件的布局

<?xml version="1.0" encoding="utf-8"?><RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"    android:layout_width="match_parent"    android:layout_height="match_parent"><EditText    android:id="@+id/et"    android:background="@drawable/bg_edittext"    android:layout_width="match_parent"    android:layout_height="match_parent"    android:layout_gravity="left|center_vertical"    android:drawableLeft="@drawable/search1"    android:paddingRight="30dp"    android:singleLine="true" /><ImageButton    android:id="@+id/ib"    android:visibility="gone"    android:layout_alignParentRight="true"    android:layout_width="20dp"    android:layout_marginLeft="5dp"    android:layout_marginRight="5dp"    android:layout_height="match_parent"    android:scaleType="centerInside"    android:background="#00000000"    android:src="@drawable/delete" /></RelativeLayout>

内容很简单,一个EditText 和 一个 ImageButton,其中android:drawableLeft="@drawable/search1"是输入框左侧图标

另外:android:background="@drawable/bg_edittext"这里引用自定义的背景,在我的另一篇文章里面有介绍:http://leoaioria.iteye.com/blog/2207587,如不用该背景,直接去掉这行或者修改即可。

2:定义好布局之后就是使用该布局并写清空内容和隐藏、显示删除按钮的事件了,代码如下

package com.hq.util;import android.content.Context;import android.text.Editable;import android.text.TextWatcher;import android.util.AttributeSet;import android.view.LayoutInflater;import android.view.View;import android.widget.EditText;import android.widget.ImageButton;import android.widget.LinearLayout;import com.hq.xbk2.R;public class EditClear extends LinearLayout{ImageButton ib;EditText et;public EditClear(Context context) {super(context);}public EditClear(Context context, AttributeSet attrs) {super(context, attrs);LayoutInflater.from(context).inflate(R.layout.editclear, this, true);init();}private void init() {ib = (ImageButton) findViewById(R.id.ib);et = (EditText) findViewById(R.id.et);et.addTextChangedListener(tw);// 为输入框绑定一个监听文字变化的监听器// 添加按钮点击事件ib.setOnClickListener(new OnClickListener() {@Overridepublic void onClick(View v) {hideBtn();// 隐藏按钮et.setText("");// 设置输入框内容为空}});}// 当输入框状态改变时,会调用相应的方法TextWatcher tw = new TextWatcher() {@Overridepublic void onTextChanged(CharSequence s, int start, int before, int count) {}@Overridepublic void beforeTextChanged(CharSequence s, int start, int count, int after) {}// 在文字改变后调用@Overridepublic void afterTextChanged(Editable s) {if (s.length() == 0) {hideBtn();// 隐藏按钮} else {showBtn();// 显示按钮}} };public void hideBtn() {// 设置按钮不可见if (ib.isShown()){ib.setVisibility(View.GONE);}}public void showBtn() {// 设置按钮可见if (!ib.isShown()){ib.setVisibility(View.VISIBLE);}}}

注意该类:用到了TextWatcher ,有兴趣的同学可以查阅下这方面的资料

3:以上步骤完成后,自定义控件就实现了,接下来就是在其它布局文件中使用了,使用方法很简单
<com.hq.util.EditClear    android:layout_width="match_parent"    android:layout_height="35dp"/>
写上完整的类名就可以了

更多相关文章

  1. Android中的界面布局之帧布局,相对布局
  2. 学习Android从0开始之基础篇(3)-视图组件之布局管理器
  3. android从xml创建控件(按钮)或直接创建控件
  4. Android 五大布局FrameLayout,LinearLayout ,AbsoluteLayout...
  5. Android的CheckBox控件的点击效果布局文件
  6. Android开发UI布局必备基础知识
  7. Android基础入门教程——2.2.1 LinearLayout(线性布局)

随机推荐

  1. 如何安装绿色版MySQL Community Server 5
  2. Linux下MySQL 5.6.27 安装教程
  3. CentOS 7下使用rpm包安装mysql 5.7.18
  4. CentOS系统中MySQL5.1升级至5.5.36
  5. MYSQL替换时间(年月日)字段时分秒不变实
  6. Mysql表,列,库增删改查问题小结
  7. MySQL的几种安装方式及配置问题小结
  8. Linux操作系统操作MySQL常用命令小结
  9. 阿里云ECS centos6.8下安装配置MySql5.7
  10. MySql版本问题sql_mode=only_full_group_