美文网首页
Android自定义View-带删除和搜索图标的EditText

Android自定义View-带删除和搜索图标的EditText

作者: 这个杀手不太累 | 来源:发表于2017-11-23 09:08 被阅读344次

    效果图:


    这里写图片描述

    直接撸代码:

    public class SearchEditText extends EditText {
    
        private static final String TAG = "SearchEditText";
    
        private Drawable searchImg, delImg;
    
        public SearchEditText(Context context) {
            super(context);
            init();
        }
    
        public SearchEditText(Context context, AttributeSet attrs) {
            super(context, attrs);
            init();
        }
    
        public SearchEditText(Context context, AttributeSet attrs, int defStyleAttr) {
            super(context, attrs, defStyleAttr);
            init();
        }
    
        @RequiresApi(api = Build.VERSION_CODES.LOLLIPOP)
        public SearchEditText(Context context, AttributeSet attrs, int defStyleAttr, int defStyleRes) {
            super(context, attrs, defStyleAttr, defStyleRes);
            init();
        }
    
        private void init() {
            int pxDimension = (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, 16,
                    getContext().getResources().getDisplayMetrics());
            setPadding(pxDimension, 0, pxDimension, 0);
            searchImg = getContext().getResources().getDrawable(R.drawable.ic_search_red_500_24dp);
            delImg = getContext().getResources().getDrawable(R.drawable.ic_delete_forever_red_500_24dp);
            addTextChangedListener(new TextWatcher() {
                @Override
                public void beforeTextChanged(CharSequence s, int start, int count, int after) {
    
                }
    
                @Override
                public void onTextChanged(CharSequence s, int start, int before, int count) {
    
                }
    
                @Override
                public void afterTextChanged(Editable s) {
                    setDrawables();//内容变换后
                }
            });
            setDrawables();
        }
    
        private void setDrawables() {
            if (length() < 1) {
                setCompoundDrawablesWithIntrinsicBounds(searchImg, null, null, null);
            } else {
                setCompoundDrawablesWithIntrinsicBounds(searchImg, null, delImg, null);
                Drawable[] compoundDrawables = getCompoundDrawables();
                // 0 ,1 ,2, 3对应左,上,右,下
                //如果图片小可以拉伸下,代码如下
    //            Rect bounds = compoundDrawables[2].getBounds();
    //            int size = (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, 2,
    //                    getContext().getResources().getDisplayMetrics());
    //            compoundDrawables[2].setBounds(bounds.left, bounds.top, bounds.right + size, bounds.bottom + size);
    //            setCompoundDrawables(compoundDrawables[0], compoundDrawables[1], compoundDrawables[2], compoundDrawables[3]);
            }
        }
    
        @Override
        public boolean onTouchEvent(MotionEvent event) {
            Drawable[] compoundDrawables = getCompoundDrawables();
            if (compoundDrawables[2] != null && event.getAction() == MotionEvent.ACTION_UP) {
                int eventX = (int) event.getRawX();
                int eventY = (int) event.getRawY();
                Rect rect = new Rect();
                getGlobalVisibleRect(rect);
                rect.left = rect.right - 100;
                if (rect.contains(eventX, eventY)) {
                    setText("");
                }
            }
            return super.onTouchEvent(event);
        }
    }
    
    

    布局文件就不贴上了,用到的图片资源也贴上,有需要的可以下载试试


    这里写图片描述 这里写图片描述 这里写图片描述

    相关文章

      网友评论

          本文标题:Android自定义View-带删除和搜索图标的EditText

          本文链接:https://www.haomeiwen.com/subject/qwbavxtx.html