前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Android自定义控件EditText实现清除和抖动功能

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

作者头像
砸漏
发布2020-10-29 19:29:27
9950
发布2020-10-29 19:29:27
举报
文章被收录于专栏:恩蓝脚本

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

源码如下:

代码语言:javascript
复制
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:

代码语言:javascript
复制
<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" /  

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

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-09-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档