Android自定义控件EditText实现清除和抖动功能

 更新时间:2017年12月07日 14:12:21   作者:难不难太难了  
这篇文章主要为大家详细介绍了Android自定义控件EditText实现清除和抖动功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了Android EditText实现清除和抖动功能的具体代码,供大家参考,具体内容如下

源码如下:

public class ClearEditText extends EditText implements View.OnFocusChangeListener,TextWatcher { 
 / 
  * 删除按钮的引用 
  */ 
 private Drawable mClearDrawable; 
 / 
  * 控件是否有焦点 
  */ 
 private boolean hasFoucs; 
 
 public ClearEditText(Context context) { 
  this(context, null); 
 } 
 public ClearEditText(Context context, AttributeSet attrs) { 
  // 这里构造方法也很重要,不加这个很多属性不能再XML里面定义 
  this(context, attrs, android.R.attr.editTextStyle); 
 } 
 
 public ClearEditText(Context context, AttributeSet attrs, int defStyle) { 
  super(context, attrs, defStyle); 
  init(); 
 } 
 private void init() { 
  // 获取EditText的DrawableRight,假如没有设置我们就使用默认的图片,2是获得右边的图片 顺序是左上右下(0,1,2,3,) 
  mClearDrawable = getCompoundDrawables()[2]; 
  if (mClearDrawable == null) { 
   // throw new 
   // NullPointerException("You can add drawableRight attribute in XML"); 
   mClearDrawable = getResources().getDrawable(R.drawable.icon_clear_input); 
  } 
 
  mClearDrawable.setBounds(0, 0, mClearDrawable.getIntrinsicWidth(),mClearDrawable.getIntrinsicHeight()); 
  // 默认设置隐藏图标 
  setClearIconVisible(false); 
  // 设置焦点改变的监听 
  setOnFocusChangeListener(this); 
  // 设置输入框里面内容发生改变的监听 
  addTextChangedListener(this); 
 } 
 
 / 
  * 因为我们不能直接给EditText设置点击事件,所以我们用记住我们按下的位置来模拟点击事件 当我们按下的位置 在 EditText的宽度 - 
  * 图标到控件右边的间距 - 图标的宽度 和 EditText的宽度 - 图标到控件右边的间距之间我们就算点击了图标,竖直方向就没有考虑 
  */ 
 @Override 
 public boolean onTouchEvent(MotionEvent event) { 
  if (event.getAction() == MotionEvent.ACTION_UP) { 
   if (getCompoundDrawables()[2] != null) { 
    boolean touchable = event.getX() > (getWidth() - getTotalPaddingRight())&& (event.getX() < ((getWidth() - getPaddingRight()))); 
    if (touchable) { 
     this.setText(""); 
    } 
   } 
  } 
  return super.onTouchEvent(event); 
 } 
 
 / 
  * 当ClearEditText焦点发生变化的时候,判断里面字符串长度设置清除图标的显示与隐藏 
  */ 
 @Override 
 public void onFocusChange(View v, boolean hasFocus) { 
  this.hasFoucs = hasFocus; 
  if (hasFocus) { 
   setClearIconVisible(getText().length() > 0); 
  } else { 
   setClearIconVisible(false); 
  } 
 } 
 
 / 
  * 设置清除图标的显示与隐藏,调用setCompoundDrawables为EditText绘制上去 
  * 
  * @param visible 
  */ 
 protected void setClearIconVisible(boolean visible) { 
  Drawable right = visible ? mClearDrawable : null; 
  setCompoundDrawables(getCompoundDrawables()[0],getCompoundDrawables()[1], right, getCompoundDrawables()[3]); 
 } 
 
 / 
  * 当输入框里面内容发生变化的时候回调的方法 
  */ 
 @Override 
 public void onTextChanged(CharSequence s, int start, int count, int after) { 
  if (hasFoucs) { 
   setClearIconVisible(s.length() > 0); 
  } 
 } 
 
 @Override 
 public void beforeTextChanged(CharSequence s, int start, int count,int after) { 
 
 } 
 
 @Override 
 public void afterTextChanged(Editable s) { 
 
 } 
 
 / 
  * 设置晃动动画 
  */ 
 public void setShakeAnimation() { 
  this.startAnimation(shakeAnimation(5)); 
 } 
 
 / 
  * 晃动动画 
  * 
  * @param counts 
  *   1秒钟晃动多少下 
  * @return 
  */ 
 public static Animation shakeAnimation(int counts) { 
  Animation translateAnimation = new TranslateAnimation(0, 10, 0, 0); 
  //设置一个循环加速器,使用传入的次数就会出现摆动的效果。 
  translateAnimation.setInterpolator(new CycleInterpolator(counts)); 
  translateAnimation.setDuration(500); 
  return translateAnimation; 
 } 
 
} 

使用方法同普通的EditText:

<com.example.clearedittext.ClearEditText  
    android:id="@+id/username"  
    android:layout_marginTop="60dp"  
    android:layout_width="fill_parent"  
    android:background="@drawable/login_edittext_bg"   
    android:drawableLeft="@drawable/icon_user"  
    android:layout_marginLeft="10dip"  
    android:layout_marginRight="10dip"  
    android:singleLine="true"  
    android:drawableRight="@drawable/delete_selector"  
    android:hint="输入用户名"  
    android:layout_height="wrap_content" /> 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

最新评论