`

自定义输入框(带clear所有内容功能)

 
阅读更多

效果图:

 

 

 

1 自定义控件CommonEditText.java代码:

package com.yiduoyun.cloudschool.view;

import android.content.Context;
import android.content.res.ColorStateList;
import android.content.res.TypedArray;
import android.graphics.Rect;
import android.graphics.drawable.Drawable;
import android.text.Editable;
import android.text.InputFilter;
import android.text.InputType;
import android.text.TextWatcher;
import android.util.AttributeSet;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.inputmethod.EditorInfo;
import android.widget.EditText;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.TextView.OnEditorActionListener;

import com.yiduoyun.cloudschool.R;

/**
 * 
 * @ClassName: CommonEditText
 * @Description: 自定义的EditText,自带清空按钮(关于密码模式,需要设置password属性为TRUE,单纯设置inputType为textPassword不起作用)
 * @author gaoshunsheng 794419070@qq.com
 * @date 2014-3-6 下午1:44:30
 * 
 */
public class CommonEditText extends LinearLayout {

	private EditText editText;
	private ImageView imgClear;

	private TextWatcher textWatcher;

	private boolean isClearFunctionWork = true; 
	
	public CommonEditText(Context context, AttributeSet attrs) {
		super(context, attrs);
		LayoutInflater.from(getContext()).inflate(
				R.layout.layout_common_edit_text, this);
		editText = (EditText) findViewById(R.id.editText);
		
		imgClear = (ImageView) findViewById(R.id.imageView);
		imgClear.setVisibility(View.GONE);
		imgClear.setOnClickListener(new View.OnClickListener() {

			@Override
			public void onClick(View v) {
				editText.setText("");
				imgClear.setVisibility(View.GONE);
			}
		});

		// 这里处理自定义的属性
		TypedArray a = context.obtainStyledAttributes(attrs,
				R.styleable.CommonEditText);
		// 设置默认文本
		CharSequence hint = a.getText(R.styleable.CommonEditText_hint);
		editText.setHint(hint);
		// 设置文字大小
		float textsize = a.getDimensionPixelSize(R.styleable.CommonEditText_textSize, -1);
		if(-1 != textsize)
		{
			editText.setTextSize(textsize);
			//这个很重要,根据TextView的setRawTextSize方法源代码获得
			editText.getPaint().setTextSize(textsize);
			editText.invalidate();
		}
		
		// 设置EditText文字颜色
		ColorStateList textColor = a
				.getColorStateList(R.styleable.CommonEditText_textColor);
		if (null != textColor) {
			editText.setTextColor(textColor);
		}
		//设置EditText的Hint的文字颜色
		ColorStateList textColorHint = a
				.getColorStateList(R.styleable.CommonEditText_textColorHint);
		if (null != textColorHint) {
			editText.setHintTextColor(textColorHint);
		}
		// 设置EditText是否单行显示
		boolean singleLine = a.getBoolean(
				R.styleable.CommonEditText_singleLine, true);
		editText.setSingleLine(singleLine);
		// 设置InputType
		int inputType = a.getInt(R.styleable.CommonEditText_inputType,
				EditorInfo.TYPE_NULL);
		Log.i("InputType", inputType + "");
		if(EditorInfo.TYPE_NULL != inputType)
		{
			editText.setInputType(inputType);
		}
		else
		{
			editText.setInputType(EditorInfo.TYPE_CLASS_TEXT);
		}

		//设置MaxLength属性
		Integer maxLength = a.getInteger(R.styleable.CommonEditText_maxLength, 0);
		if(0 != maxLength)
		{
			InputFilter[] filters = {new InputFilter.LengthFilter(maxLength.intValue())};
			editText.setFilters(filters);
		}
		
		// 设置清空按钮的宽高
		int clearH = a.getDimensionPixelSize(
				R.styleable.CommonEditText_clearButtonHeight, -1);
		int clearW = a.getDimensionPixelSize(
				R.styleable.CommonEditText_clearButtonWidth, -1);
		if (-1 != clearH && -1 != clearW) {
			imgClear.setLayoutParams(new LayoutParams(clearH, clearW));
		}

		// 设置按钮的Padding
		int padding = a.getDimensionPixelSize(
				R.styleable.CommonEditText_clearButtonPadding, -1);
		if (-1 != padding) {
			imgClear.setPadding(padding, padding, padding, padding);
		}
		
		//设置密码模式
		boolean password = a.getBoolean(R.styleable.CommonEditText_password, false);
		if(password)
		{
			editText.setInputType(InputType.TYPE_CLASS_TEXT|InputType.TYPE_TEXT_VARIATION_PASSWORD);
		}
		//设置清空按钮图标
		Drawable drawableClear = a.getDrawable(R.styleable.CommonEditText_drawableClearButton);
		if(null != drawableClear)
		{
			imgClear.setImageDrawable(drawableClear);
		}
		//设置清空按钮显示状态
		boolean enableClearFunction = a.getBoolean(R.styleable.CommonEditText_enableClearFunction, true);
		isClearFunctionWork = enableClearFunction;
		//设置EditText监听
		editText.addTextChangedListener(new TextWatcher() {

			@Override
			public void afterTextChanged(Editable s) {

			}

			@Override
			public void beforeTextChanged(CharSequence s, int start, int count,
					int after) {

			}

			@Override
			public void onTextChanged(CharSequence s, int start, int before,
					int count) {
				if(isClearFunctionWork)
				{
					toggleClearButton(s);
				}

			}

		});
		editText.setOnFocusChangeListener(new OnFocusChangeListener() {

			@Override
			public void onFocusChange(View v, boolean hasFocus) {
				if(isClearFunctionWork)
				{
					toggleClearButtonOnFocus(hasFocus);
				}
			}

		});
		a.recycle();
	}

	/**
	 * 切换清空按钮
	 * 
	 * @param s
	 */
	private void toggleClearButton(CharSequence s) {
		if (s.length() > 0) {
			imgClear.setVisibility(View.VISIBLE);
		} else {
			imgClear.setVisibility(View.GONE);
		}
	}

	/**
	 * 聚焦处理事件
	 * 
	 * @param onFocusChangeListener
	 */
	public void setOnFocusChangeListener(
			final OnFocusChangeListener onFocusChangeListener) {
		editText.setOnFocusChangeListener(new OnFocusChangeListener() {

			@Override
			public void onFocusChange(View v, boolean hasFocus) {
				if(isClearFunctionWork)
				{
					toggleClearButtonOnFocus(hasFocus);
				}
				onFocusChangeListener.onFocusChange(v, hasFocus);
			}

		});
	}

	private void toggleClearButtonOnFocus(boolean hasFocus) {
		if (!hasFocus) {
			imgClear.setVisibility(View.GONE);
		} 
		else if(hasFocus && editText.getText().length() > 0)
		{
			imgClear.setVisibility(View.VISIBLE);
		}
	}

	@Override
	protected void onFocusChanged(boolean gainFocus, int direction,
			Rect previouslyFocusedRect) {
		if(gainFocus)
		{
			editText.requestFocus();
		}
		super.onFocusChanged(gainFocus, direction, previouslyFocusedRect);
	}
	
	/**
	 * 设置密码模式
	 */
	public void setPasswordMode()
	{
		editText.setInputType(InputType.TYPE_CLASS_TEXT|InputType.TYPE_TEXT_VARIATION_PASSWORD);
	}
	
	/**
	 * 编辑动作监听器,对键盘上的操作作监听
	 * 
	 * @param onEditorActionListener
	 */
	public void setOnEditorActionListener(
			OnEditorActionListener onEditorActionListener) {
		editText.setOnEditorActionListener(onEditorActionListener);
	}

	/**
	 * 文本输入框内容改变事件
	 * 
	 * @param textWatcherImpl
	 */
	public void addTextChangedListener(TextWatcher textWatcherImpl) {
		this.textWatcher = textWatcherImpl;
		editText.addTextChangedListener(new TextWatcher() {

			@Override
			public void onTextChanged(CharSequence s, int start, int before,
					int count) {
				textWatcher.onTextChanged(s, start, before, count);
			}

			@Override
			public void beforeTextChanged(CharSequence s, int start, int count,
					int after) {
				textWatcher.beforeTextChanged(s, start, count, after);
			}

			@Override
			public void afterTextChanged(Editable s) {
				if(isClearFunctionWork)
				{
					toggleClearButton(s);
				}
				textWatcher.afterTextChanged(s);
			}
		});
	}

	public CommonEditText(Context context) {
		super(context);
	}

	/**
	 * //设置清空按钮显示状态
	 * @param showClearButton
	 */
	public void showClearButton(boolean showClearButton)
	{
		imgClear.setVisibility(showClearButton ? View.VISIBLE : View.GONE);
	}
	
	/*
	 * 返回EditText对象
	 */
	public EditText getEditText()
	{
		return editText;
	}
	
	public int getSelectionStart()
	{
		return editText.getSelectionStart();
	}
	
	public int getSelectionEnd()
	{
		return editText.getSelectionEnd();
	}
	
	public void setSelection(int selection)
	{
		editText.setSelection(selection);
	}
	
	public void setText(CharSequence charSequence)
	{
		editText.setText(charSequence);
	}
	
	public CharSequence getText()
	{
		return editText.getText();
	}
	
	public void setInputType(int inputType){
		editText.setInputType(inputType);
	}

	/**
	 * 设置文本输入框提示文本
	 * 
	 * @param hint
	 */
	public void setHint(String hint) {
		editText.setHint(hint);
	}

	/**
	 * 设置清空按钮Drawable对象
	 * @param drawable
	 */
	public void setClearButtonDrawable(Drawable drawable) {
		imgClear.setImageDrawable(drawable);
	}
}

 

 

2 布局代码layout_common_edit_text.xml:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
	android:paddingLeft="10dp"
	android:paddingRight="10dp"    
    android:layout_gravity="center_vertical"
    android:gravity="center_vertical"
    android:orientation="horizontal" >

    <EditText 
        android:id="@+id/editText"
        android:layout_weight="1"
        android:cursorVisible="true"
        android:focusable="true"
        android:focusableInTouchMode="true"
        android:textCursorDrawable="@null"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:background="@null"
        />
    
    <ImageView
        android:id="@+id/imageView"
        android:layout_weight="0"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:src="@drawable/delete" />
   
</LinearLayout>

 

 

3 在values文件夹下加入样式文件editText_attrs.xml:

<?xml version="1.0" encoding="utf-8"?>
<resources>

    <declare-styleable name="CommonEditText">
    <!-- set editText hint -->
	<attr name="hint" format="string" />
	<!-- set editText textSize -->
	<attr name="textSize" format="dimension" />
	<!-- set editText textColor -->
	<attr name="textColor" format="reference|color" />
	<!-- set editText textColorHint -->
	<attr name="textColorHint" format="reference|color" />
	<!-- set editText inpuType -->
	<attr name="inputType">
        <flag name="none" value="0x00000000" />
        <flag name="text" value="0x00000001" />
        <flag name="textCapCharacters" value="0x00001001" />
        <flag name="textCapWords" value="0x00002001" />
        <flag name="textCapSentences" value="0x00004001" />
        <flag name="textAutoCorrect" value="0x00008001" />
        <flag name="textAutoComplete" value="0x00010001" />
        <flag name="textMultiLine" value="0x00020001" />
        <flag name="textImeMultiLine" value="0x00040001" />
        <flag name="textNoSuggestions" value="0x00080001" />
        <flag name="textUri" value="0x00000011" />
        <flag name="textEmailAddress" value="0x00000021" />
        <flag name="textEmailSubject" value="0x00000031" />
        <flag name="textShortMessage" value="0x00000041" />
        <flag name="textLongMessage" value="0x00000051" />
        <flag name="textPersonName" value="0x00000061" />
        <flag name="textPostalAddress" value="0x00000071" />
        <flag name="textPassword" value="0x00000081" />
        <flag name="textVisiblePassword" value="0x00000091" />
        <flag name="textWebEditText" value="0x000000a1" />
        <flag name="textFilter" value="0x000000b1" />
        <flag name="textPhonetic" value="0x000000c1" />
        <flag name="textWebEmailAddress" value="0x000000d1" />
        <flag name="textWebPassword" value="0x000000e1" />
        <flag name="number" value="0x00000002" />
        <flag name="numberSigned" value="0x00001002" />
        <flag name="numberDecimal" value="0x00002002" />
        <flag name="numberPassword" value="0x00000012" />
        <flag name="phone" value="0x00000003" />
        <flag name="datetime" value="0x00000004" />
        <flag name="date" value="0x00000014" />
        <flag name="time" value="0x00000024" />
    </attr>
    <!-- set clear button padding -->
    <attr name="clearButtonPadding" format="dimension" />
    <!-- set clear button height -->
    <attr name="clearButtonHeight" format="dimension" />
    <!-- set clear button width -->
    <attr name="clearButtonWidth" format="dimension" />
    <!-- set editText height -->
    <attr name="editTextHeight" format="dimension" />
    <!-- set editText password -->
    <attr name="password" format="boolean" />
    <!-- set editText singleLine -->
    <attr name="singleLine" format="boolean" />
    <!-- set clearButton function works or not -->
    <attr name="enableClearFunction" format="boolean" />
    <!-- set editText maxLength -->
    <attr name="maxLength" format="integer" min="0" />
    <!-- set clearButton Drawable -->
    <attr name="drawableClearButton" format="reference" />
    </declare-styleable>

</resources>

 

 

如上图的布局为:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res/com.yiduoyun.cloudschool"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#f0f0f0"
    android:orientation="vertical"
    android:padding="15dp" >

    <com.yiduoyun.cloudschool.view.CommonEditText
        android:id="@+id/input_new_phonenumber"
        android:layout_width="fill_parent"
        android:layout_height="50dp"
        android:background="@drawable/setting_input_shape"
        android:maxLength="20"
        android:paddingLeft="15dp"
        android:paddingRight="15dp"
        app:clearButtonHeight="40dp"
        app:clearButtonPadding="10dp"
        app:clearButtonWidth="40dp"
        app:hint="@string/input_new_phone"
        app:inputType="phone"
        app:singleLine="true"
        app:textColor="#000000"
        app:textColorHint="#707070"
        app:textSize="14sp" />

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginTop="20dp"
        android:orientation="horizontal" >

        <TextView
            android:id="@+id/send_authcode"
            android:layout_width="0dp"
            android:layout_height="40dp"
            android:layout_weight="1"
            android:background="#B9E5F0"
            android:gravity="center"
            android:text="@string/send_authcode"
            android:textColor="#01A9CD" />

        <com.yiduoyun.cloudschool.view.CommonEditText
            android:id="@+id/input_authcode"
            android:layout_width="0dp"
            android:layout_height="40dp"
            android:layout_marginLeft="15dp"
            android:layout_weight="1"
            android:background="@drawable/setting_input_shape"
            android:paddingLeft="12dp"
            android:paddingRight="12dp"
            app:clearButtonHeight="40dp"
            app:clearButtonPadding="10dp"
            app:clearButtonWidth="40dp"
            app:hint="@string/input_authcode"
            app:inputType="number"
            app:singleLine="true"
            app:textColor="#000000"
            app:textColorHint="#707070"
            app:textSize="14sp" />
    </LinearLayout>

</LinearLayout>

 

 

 

5 附加一个输入框的shape文件setting_input_shape.xml:

<?xml version="1.0" encoding="UTF-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
    
   <!-- 实心 -->
   <solid android:color="#ffffff"/>
   <!-- 描边 -->
   <stroke
       android:width="1dp"
       android:color="#E2E2E2" />
    
</shape>

 

控件就可以使用了.

  • 大小: 48.8 KB
  • 大小: 104.5 KB
  • 大小: 5.3 KB
分享到:
评论

相关推荐

    Android自定义EditText实现带清除功能的输入框

    本教程将详细讲解如何在Android中自定义一个带有清除功能的EditText输入框。 首先,我们来理解为什么需要这个功能。在许多应用程序中,用户在输入文字后,可能会想要快速清空输入框,这时一个明显的清除图标(通常...

    安卓EditText输入框相关-Android自定义EditText实现带清除功能的输入框.rar

    这个压缩包文件"Android自定义EditText实现带清除功能的输入框"显然就是针对这一需求的示例代码。 首先,我们来看看如何在Android中自定义一个带有清除按钮的EditText。通常,我们会创建一个新的XML布局文件,包含...

    带删除按钮的输入框

    这个功能通常通过自定义一个EditText控件来实现,为用户提供便捷的方式来清除输入框的内容,类似于iOS中的文本字段。 首先,我们需要创建一个新的类,继承自EditText。在这个类中,我们将添加一个"删除"按钮,通常...

    Android 带清除功能的输入框控件

    为了提升用户体验,许多应用会在输入框旁边添加一个清除按钮,允许用户快速清空输入内容。本篇文章将深入探讨如何在Android中实现带有清除功能的`EditText`控件。 一、`EditText`基础 `EditText`继承自`TextView`...

    安卓EditText输入框相关-输入框一键删除内容。两种方法实现.rar

    本文将详细讲解如何实现EditText输入框的一键删除内容功能,即点击一个按钮或者设置某个快捷方式,可以快速清除输入框中的所有文字。 首先,我们来看第一种方法:使用监听器(OnClickListener)实现一键删除。在...

    [Android实例] 带clean按钮的输入框

    在Android开发中,创建一个带有“清洁”按钮的输入框是一项常见的需求,它通常用于清除用户输入的内容,提供更友好的交互体验。本实例将详细讲解如何实现这样一个功能。 首先,我们需要在XML布局文件中定义一个...

    可清除的输入框

    要创建一个带有清除按钮的`EditText`,我们可以扩展`EditText`类,并自定义它的视图。这通常涉及到重写`onDraw()`方法或者使用`CompoundButton`(如`CheckBox`或`ImageButton`)作为清除图标,通过监听按钮的点击...

    Android例子源码自定义带有删除功能的edittext实例.zip

    通过这个自定义的ClearableEditText,开发者可以在不引入额外库的情况下,轻松地在登录、搜索等界面实现一个功能完备且用户体验良好的输入框。同时,这也是Android开发中实践组件复用和提高代码可维护性的一个好例子...

    带有删除的输入框<DeleteEditext>

    这种特殊的输入框被称为“带有删除功能的输入框”或者“DeleteEditText”。这个组件的实现不仅提高了用户界面的交互性,也提升了用户体验。 首先,我们要理解`DeleteEditText`的基本概念。它是在标准的`EditText`...

    带删除的输入框 DeleteEditext

    在Android开发中,一个常见的需求是为用户界面创建带有清除按钮的输入框,这通常用于让用户方便地清除已输入的内容。这种特殊的输入框被称为“带删除的输入框”或者“DeleteEditText”。它在传统的EditText的基础上...

    扩展EditText(带清除、卡号、电话号码格式输入框)

    本文将深入探讨如何扩展EditText,实现带有清除按钮、卡号四位加空格输入以及电话号码格式化的功能。 首先,我们要创建一个自定义的EditText类,继承自系统的EditText。在自定义类中,我们可以重写一些关键方法来...

    自带删除功能的输入框——在登录,搜索等地方经常用到可以直接用

    在Android开发中,我们经常会遇到需要创建带有删除功能的输入框的情况,比如登录界面的账号输入、搜索框等。这种输入框通常会在文本输入框的右侧添加一个“清除”按钮,用户点击该按钮即可快速清空输入内容。本文将...

    带清除图标的 EditText ( 自定义EditText

    通过以上步骤,我们成功地自定义了一个带有清除图标的`EditText`,它可以根据文本内容自动显示或隐藏清除图标,并且当点击图标时,会清空输入框中的内容。这种方法不仅可以提高用户交互体验,还可以使应用界面更加...

    EditText输入框筛选listview内容

    本篇文章将深入探讨如何实现 `EditText` 输入框筛选 `ListView` 内容这一功能。 首先,我们需要创建一个 `ListView` 并为它设置适配器。适配器通常会是 `ArrayAdapter`、`BaseAdapter` 或者自定义的适配器,用于将...

    仿支付宝密码输入框

    在这个项目中,我们将深入探讨如何实现这样一个功能强大的输入框。 首先,我们要理解这个自定义控件的核心目标:模仿支付宝应用中的密码输入界面,该界面通常具有以下特点: 1. **显示模式**:用户输入的每个字符...

    iOS输入框清除按钮

    在iOS开发中,输入框...总的来说,实现iOS输入框的清除按钮功能涉及设置`UITextField`的属性、添加自定义视图以及监听文本变化以控制清除按钮的显示。这个功能提高了用户体验,让用户能快速、直观地清除输入内容。

    IP地址输入框c#源码

    本篇文章将详细讲解如何利用C#编程语言实现一个类似于Windows网络适配器设置中IP地址输入框的功能。 首先,我们要理解IP地址的基本概念。IP地址(Internet Protocol Address)是互联网上的设备身份标识,由32位二...

    AmazeUI 输入框组

    - 输入框通常带有`am-form-control`类,用于应用相应的样式和行为。 - 标签使用`&lt;label&gt;`元素,并通过`for`属性与对应的`&lt;input&gt;`元素关联,以实现点击标签聚焦输入框的效果。 2. **响应式设计**: - AmazeUI...

    QCombox自动提示,仿谷歌搜索功能

    在实际应用中,我们经常需要实现类似谷歌搜索那样的输入自动提示功能,即用户在输入框中输入文字时,系统能够实时给出匹配的建议。在本项目“QCombox自动提示,仿谷歌搜索功能”中,我们将看到如何结合`QComboBox`和...

    datetimepicker加上清空功能

    值得注意的是,这样的修改可能并不适用于所有用户,因为某些场景下用户可能依然需要“Today”功能。因此,提供自定义选项或让用户选择是否显示“Today”按钮会是一个更好的设计策略。这样既能满足有清空需求的用户,...

Global site tag (gtag.js) - Google Analytics