首页 > 代码库 > 【Android-EditText】自定义带删除功能的EditText

【Android-EditText】自定义带删除功能的EditText

我们经常在一些应用中见到输入框带有删除功能,今天我们就来实现这个功能(文字组织能力不强,大家随便看看)。主要是记录一下自己的学习经历,如果对大家有帮助,我会更开心的。

先上图:

wKiom1NoiWKxPyZ1AAF6K_ZbO_g941.jpg

实现要点:

1、当输入框为空时,删除按钮隐藏;

2、当输入框不为空时,显示删除按钮。


核心代码:

package com.example.view;
import com.example.ui.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.view.MotionEvent;
import android.view.View;
import android.widget.EditText;
import android.widget.Toast;
import android.view.View.OnFocusChangeListener;;
public class EditTextWithDelete extends EditText implements OnFocusChangeListener{
    private Drawable imgEnable;
    private Context context;
                                                                                
    public EditTextWithDelete(Context context) {
        super(context);
        this.context = context;
        init();
    }
    public EditTextWithDelete(Context context, AttributeSet attrs, int defStyle) {
        super(context, attrs, defStyle);
        this.context = context;
        init();
    }
    public EditTextWithDelete(Context context, AttributeSet attrs) {
        super(context, attrs);
        this.context = context;
        init();
    }
                                                                                
    private void init() {
        //获取图片资源
        imgEnable = context.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();
                Toast.makeText(context, getText(), 10).show();
            }
        });
        setDrawable();
    }
                                                                                
    /**
     * 设置删除图片
     */
    private void setDrawable() {
        if(length() == 0) {
            setCompoundDrawablesWithIntrinsicBounds(null, null, null, null);
        }else {
            setCompoundDrawablesWithIntrinsicBounds(null, null, imgEnable, null);
        }
    }
                                                                                
    /**
     * event.getX() 获取相对应自身左上角的X坐标
     * event.getY() 获取相对应自身左上角的Y坐标
     * getWidth() 获取控件的宽度
     * getTotalPaddingRight() 获取删除图标左边缘到控件右边缘的距离
     * getPaddingRight() 获取删除图标右边缘到控件右边缘的距离
     * getWidth() - getTotalPaddingRight() 计算删除图标左边缘到控件左边缘的距离
     * getWidth() - getPaddingRight() 计算删除图标右边缘到控件左边缘的距离
     */
    @Override
    public boolean onTouchEvent(MotionEvent event) {
        if(imgEnable != null && event.getAction() == MotionEvent.ACTION_UP) {
            int x = (int) event.getX() ;
            //判断触摸点是否在水平范围内
            boolean isInnerWidth = (x > (getWidth() - getTotalPaddingRight())) &&
                    (x < (getWidth() - getPaddingRight()));
            //获取删除图标的边界,返回一个Rect对象
            Rect rect = imgEnable.getBounds();
            //获取删除图标的高度
            int height = rect.height();
            int y = (int) event.getY();
            //计算图标底部到控件底部的距离
            int distance = (getHeight() - height) /2;
            //判断触摸点是否在竖直范围内(可能会有点误差)
            //触摸点的纵坐标在distance到(distance+图标自身的高度)之内,则视为点中删除图标
            boolean isInnerHeight = (y > distance) && (y < (distance + height));
                                                                                        
            if(isInnerWidth && isInnerHeight) {
                setText("");
            }
                                                                                        
        }
                                                                                    
        return super.onTouchEvent(event);
    }
                                                                                
    @Override
    protected void finalize() throws Throwable {
        super.finalize();
    }
    @Override
    public void onFocusChange(View v, boolean hasFocus) {
        if(hasFocus) {
            setDrawable();
        }else {
            setCompoundDrawablesWithIntrinsicBounds(null, null, null, null);
        }
    }
                                                                                
}

代码注释很清楚,相信以大家的水平都会看的懂的。在这边,我就不多做解释了。如果有不明白的,可以给我留言,大家交流交流。

本文出自 “简单的IT生活” 博客,请务必保留此出处http://jychen.blog.51cto.com/4792328/1407209