androidUI设计之旅 ----自定义EditText(多了一个清除按钮)

     csdn怎么了,上传的代码都是乱的。。。。。。。。。

       今天我要自定义一个EditText,主要实现的效果是,没输入字符的时候,后面没有清空按钮,输入的时候,就会出现。不废话,直接上图。

一:效果介绍:


这个效果是不是很酷呢?把它封装成一个类,就不用每次都写了。直接当控件用了。

二:代码

(1)user_definedet.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="horizontal" >

    <EditText
        android:id="@+id/user_define_et"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_toLeftOf="@+id/user_define_iv" />

    <ImageView
        android:id="@id/user_define_iv"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentRight="true"
        android:layout_centerVertical="true"
        android:background="@drawable/icon_clear" />

</RelativeLayout>


(2)UserDefineEditText.java

package com.example.userdefinedet;

import android.content.Context;
import android.text.Editable;
import android.text.TextWatcher;
import android.util.AttributeSet;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.EditText;
import android.widget.ImageView;
import android.widget.LinearLayout;

public class UserDefineEditText extends LinearLayout implements TextWatcher,
		OnClickListener {
	private EditText mEdiText;
	private ImageView mImageView;

	public UserDefineEditText(Context context) {
		super(context);
		initView();
	}

	public UserDefineEditText(Context context, AttributeSet attrs, int defStyle) {
		super(context, attrs, defStyle);
		initView();
	}

	public UserDefineEditText(Context context, AttributeSet attrs) {
		super(context, attrs);
		initView();
	}

	// 初始化视图
	private void initView() {
		View view = View.inflate(getContext(), R.layout.user_definedet, null);
		mEdiText = (EditText) view.findViewById(R.id.user_define_et);
		mImageView = (ImageView) view.findViewById(R.id.user_define_iv);
		mImageView.setVisibility(View.GONE);
		mEdiText.addTextChangedListener(this);
		mImageView.setOnClickListener(this);
		addView(view);

	}

	@Override
	public void afterTextChanged(Editable s) {
		// TODO Auto-generated metho
		if (s.length() > 0) {
			mImageView.setVisibility(View.VISIBLE);
		} else {
			mImageView.setVisibility(View.GONE);
		}

	}

	@Override
	public void beforeTextChanged(CharSequence s, int start, int count,
			int after) {
		// TODO Auto-generated method stub

	}

	@Override
	public void onTextChanged(CharSequence s, int start, int before, int count) {
		// TODO Auto-generated method stub

	}

	@Override
	public void onClick(View v) {
		switch (v.getId()) {
		case R.id.user_define_iv:
			mEdiText.setText("");
			break;

		default:
			break;
		}

	}

	public String getText() {
		return mEdiText.getText().toString();
	}

}

(3)使用这个控件的两种方法:
       (1)new UserDefineEditText(this);
         this:指的是“上下文”
    (2)在布局文件中引入:

如:
    
<com.example.userdefinedet.UserDefineEditText
            android:id="@+id/userdefineedittext"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" >
        </com.example.userdefinedet.UserDefineEditText>




源码下载地址:
http://download.csdn.net/detail/zz20104534/6861373

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。