android自定義View之自定義EditText(新增刪除功能)
阿新 • • 發佈:2018-12-23
忙忙碌碌20天,新的專案終於接近尾聲了。今天公司召集幾個使用者體驗師和美工一起吐糟這20天做的這個新產品,對於產品提出了很多建議,這幾天就改介面了。在這個專案中大量的使用了EditText元件,並且添加了刪除功能。這裡面都是用RelativeLayout佈局將一個包含刪除圖片的ImageView放到EditText中的右邊。然後對ImageView新增事件,進行刪除。以前都是這樣乾的,相信大多數也是這樣乾的。可是今天使用者體驗師提出要求在EditText在沒有內容的時候刪除圖片顯示為灰色,有內容的時候顯示為專案的主題色。靠,專案中用了40多個,要改死我。不過也怪自己在專案開始時沒考慮到EditText的複用。
為了更高的複用和減少程式碼的冗餘所以按照使用者體驗師的要求自定義了一個EditText。
EditTextWithDel元件的功能如下:
1、在沒用內容的時候顯示不可用的圖片狀態,在有內容的時候顯示可用的圖片狀態;
2、在有內容的時候點選刪除按鈕可以刪除EditText中的內容;
元件的程式碼如下:
package com.sunday.customs; import com.example.customs.R; import android.content.Context; import android.graphics.Rect; import android.graphics.drawable.Drawable; import android.text.Editable; import android.text.TextWatcher; import android.util.AttributeSet; import android.util.Log; import android.view.MotionEvent; import android.widget.EditText; /** * @author sunday * 2013-12-04 */ public class EditTextWithDel extends EditText { private final static String TAG = "EditTextWithDel"; private Drawable imgInable; private Drawable imgAble; private Context mContext; public EditTextWithDel(Context context) { super(context); mContext = context; init(); } public EditTextWithDel(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); mContext = context; init(); } public EditTextWithDel(Context context, AttributeSet attrs) { super(context, attrs); mContext = context; init(); } private void init() { imgInable = mContext.getResources().getDrawable(R.drawable.delete_gray); imgAble = mContext.getResources().getDrawable(R.drawable.delete); addTextChangedListener(new TextWatcher() { @Override public void onTextChanged(CharSequence s, int start, int before, int count) {} @Override public void beforeTextChanged(CharSequence s, int start, int count, int after) {} @Override public void afterTextChanged(Editable s) { setDrawable(); } }); setDrawable(); } //設定刪除圖片 private void setDrawable() { if(length() < 1) setCompoundDrawablesWithIntrinsicBounds(null, null, imgInable, null); else setCompoundDrawablesWithIntrinsicBounds(null, null, imgAble, null); } // 處理刪除事件 @Override public boolean onTouchEvent(MotionEvent event) { if (imgAble != null && event.getAction() == MotionEvent.ACTION_UP) { int eventX = (int) event.getRawX(); int eventY = (int) event.getRawY(); Log.e(TAG, "eventX = " + eventX + "; eventY = " + eventY); Rect rect = new Rect(); getGlobalVisibleRect(rect); rect.left = rect.right - 50; if(rect.contains(eventX, eventY)) setText(""); } return super.onTouchEvent(event); } @Override protected void finalize() throws Throwable { super.finalize(); } }
效果圖如下: