当前位置: 首页 > 编程笔记 >

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

轩辕煜
2023-03-14
本文向大家介绍Android自定义控件EditText实现清除和抖动功能,包括了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" /> 

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

 类似资料:
  • 本文向大家介绍Android输入框控件ClearEditText实现清除功能,包括了Android输入框控件ClearEditText实现清除功能的使用技巧和注意事项,需要的朋友参考一下 本文给大家带来一个很实用的小控件ClearEditText,就是在Android系统的输入框右边加入一个小图标,点击小图标可以清除输入框里面的内容,IOS上面直接设置某个属性就可以实现这一功能,但是Android

  • 本文向大家介绍Android组合控件实现功能强大的自定义控件,包括了Android组合控件实现功能强大的自定义控件的使用技巧和注意事项,需要的朋友参考一下 通常情况下,Android实现自定义控件无非三种方式。   Ⅰ、继承现有控件,对其控件的功能进行拓展。   Ⅱ、将现有控件进行组合,实现功能更加强大控件。   Ⅲ、重写View实现全新的控件   上文说过了如何继承现有控件来自定义控件:《And

  • 本文向大家介绍Android自定义控件实现简单写字板功能,包括了Android自定义控件实现简单写字板功能的使用技巧和注意事项,需要的朋友参考一下 先来看看效果图 就是简单的根据手指写下的轨迹去画出内容 一、实现 之前一篇文章里提到了android官方给出的自定义控件需要考虑以下几点: 创建View 处理View的布局 绘制View 与用户进行交互 优化已定义的View 就按照这个步骤来完成今天的

  • 本文向大家介绍Android自定义EditText实现登录界面,包括了Android自定义EditText实现登录界面的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了Android自定义EditText实现登录界面的具体代码,供大家参考,具体内容如下 先看效果图: 自定义edittext 控件,监听focus和textchange 状态 实现是否显示删除图片。 自定义TextView

  • 本文向大家介绍Android自定义View实现随手势滑动控件,包括了Android自定义View实现随手势滑动控件的使用技巧和注意事项,需要的朋友参考一下 本文控件为大家分享了Android随手势滑动控件的具体代码,供大家参考,具体内容如下 1.新建自定义控件类:MyView 上面代码就是一个自定义按钮类,重写onTouchEvent()方法来监听用户滑动,既然说到滑动肯定会存在偏移量的说法。 t

  • 本文向大家介绍Android自定义控件实现折线图,包括了Android自定义控件实现折线图的使用技巧和注意事项,需要的朋友参考一下 本文实例实现一个如下图所示的Android折线图,供大家参考,具体内容如下 首先是控件绘图区域的划分,控件左边取一小部分(控件总宽度的八分之一)绘制表头,右边剩余的部分绘制表格 确定表格的行列数,首先绘制一个三行八列的网格,设置好行列的坐标后开始绘制 网格绘制完成后,

  • 本文向大家介绍Android自定义控件实现饼状图,包括了Android自定义控件实现饼状图的使用技巧和注意事项,需要的朋友参考一下 本文实现一个如图所示的控件,包括两部分,左边的饼状图和中间的两个小方块,及右边的两行文字 实现起来比较简单,只是一些绘图API的调用 核心代码在onDraw函数里边,对静态控件进行绘制即可 Canvas 绘制文本时,使用FontMetrics对象,计算位置的坐标。参考

  • 本文向大家介绍Android自定义View实现打钩动画功能,包括了Android自定义View实现打钩动画功能的使用技巧和注意事项,需要的朋友参考一下 先上效果图 动图 静态图 1. 回顾 【Android自定义View:一个精致的打钩小动画】上一篇文章,我们已经实现了基本上实现了控件的效果了,但是...但是...过了三四天后,仔细看回自己写的代码,虽然思路还在,但是部分代码还是不能一下子的看得明