在Android的輸入框中加入清除按鈕,是很常見的設計,本文介紹如何建立一個控件,
在輸入框中加入清除按鈕。android
咱們來看看實現這個控件都須要作什麼:
1. 清除按鈕在輸入框中有內容時出現
2. 清除按鈕必須出如今輸入框內
3. 點擊清除按鈕,清除輸入框中的全部內容
4. 清除按鈕的顏色必須與主題一致git
實現第一點,咱們能夠經過加入TextWatcher來監聽EditText的變化,在onFocusChangeListener方法中處理清除按鈕是否可見。
實現第二點,咱們須要使用compound drawable做爲清除按鈕,而後在 OnTouch listener中處理點擊事件。github
咱們使用AppCompatEditText做爲基類swift
public class ClearableEditText extends AppCompatEditText implements View.OnTouchListener, View.OnFocusChangeListener, TextWatcher {
接着加入構造函數微信
public ClearableEditText(final Context context) { super(context); init(context); } public ClearableEditText(final Context context, final AttributeSet attrs) { super(context, attrs); init(context); } public ClearableEditText(final Context context, final AttributeSet attrs, final int defStyleAttr) { super(context, attrs, defStyleAttr); init(context); }
實現init方法
* 建立drawable,併爲其加入Touch、Focus事件處理
* 加入TextChangedListener,監聽EditText內容變化app
private void init(final Context context) { final Drawable drawable = ContextCompat.getDrawable(context, R.drawable.abc_ic_clear_mtrl_alpha); final Drawable wrappedDrawable = DrawableCompat.wrap(drawable); //Wrap the drawable so that it can be tinted pre Lollipop DrawableCompat.setTint(wrappedDrawable, getCurrentHintTextColor()); mClearTextIcon = wrappedDrawable; mClearTextIcon.setBounds(0, 0, mClearTextIcon.getIntrinsicHeight(), mClearTextIcon.getIntrinsicHeight()); setClearIconVisible(false); super.setOnTouchListener(this); super.setOnFocusChangeListener(this); addTextChangedListener(this); }
咱們默認使用setClearIconVisible(false)
隱藏了清除按鈕,在輸入文本時纔會顯示ide
private void setClearIconVisible(final boolean visible) { mClearTextIcon.setVisible(visible, false); final Drawable[] compoundDrawables = getCompoundDrawables(); setCompoundDrawables( compoundDrawables[0], compoundDrawables[1], visible ? mClearTextIcon : null, compoundDrawables[3]); }
private Drawable mClearTextIcon; private OnFocusChangeListener mOnFocusChangeListener; private OnTouchListener mOnTouchListener; @Override public void setOnFocusChangeListener(final OnFocusChangeListener onFocusChangeListener) { mOnFocusChangeListener = onFocusChangeListener; } @Override public void setOnTouchListener(final OnTouchListener onTouchListener) { mOnTouchListener = onTouchListener; }
最後咱們來實現3個Listener,先來看focus Listener函數
@Override public void onFocusChange(final View view, final boolean hasFocus) { if (hasFocus) { setClearIconVisible(getText().length() > 0); } else { setClearIconVisible(false); } if (mOnFocusChangeListener != null) { mOnFocusChangeListener.onFocusChange(view, hasFocus); } }
在獲取焦點時,判斷輸入框中內容是否大於0,有內容則顯示清除按鈕。this
接着咱們來看onTouch方法:spa
@Override public boolean onTouch(final View view, final MotionEvent motionEvent) { final int x = (int) motionEvent.getX(); if (mClearTextIcon.isVisible() && x > getWidth() - getPaddingRight() - mClearTextIcon.getIntrinsicWidth()) { if (motionEvent.getAction() == MotionEvent.ACTION_UP) { setText(""); } return true; } return mOnTouchListener != null && mOnTouchListener.onTouch(view, motionEvent); }
在這裏,咱們首先檢查了清除按鈕是否爲顯示狀態,而後判斷點擊的範圍是否在清除按鈕內,
若是在範圍內的話,在ACTION_UP時清空輸入框內容,不然執行mOnTouchListener的
onTouch方法。
最後,咱們實現TextWatcher:
@Override public final void onTextChanged(final CharSequence s, final int start, final int before, final int count) { if (isFocused()) { setClearIconVisible(s.length() > 0); } } @Override public void beforeTextChanged(CharSequence s, int start, int count, int after) { } @Override public void afterTextChanged(Editable s) { }
判斷輸入框中的字數,大於0則顯示清除按鈕,不然隱藏。
若是你使用的是AutoCompleteTextView,咱們也能夠使用一樣的方法添加清除按鈕:
public class ClearableAutoCompleteTextView extends AppCompatAutoCompleteTextView implements View.OnTouchListener, View.OnFocusChangeListener, TextWatcher {
該控件的源碼已上傳到Github: ClearableEditText
本文譯自:Giving your Edit Texts the All Clear
本文做者: 陽春麪
原文地址:http://www.aswifter.com/2015/07/31/android-edittext-add-clear-button/
歡迎關注個人微信公衆號,分享Android 開發,IOS開發,Swift開發和互聯網內容
微信號:APP開發者