EditText ,首先他是TextView的子类,然后说实话是一个非常麻烦的组件。。
1、EditText 焦点的获取与动态设置键盘的显示与隐藏。通过监听它的OnFocusChangeListener事件,来设置软键盘的显示与隐藏。用下面的几句话:
//获取输入管理器
InputMethodManager imm = context.getSystemService(Context.INPUT_METHOD_SERVICE);
//显示与隐藏
imm.showSoftInput(v,0);
imm.hideSoftInputFromWindow(v.getWindowToken, 0);
但是在实际开发中,我遇到了一个问题。我有很多个EditText,每一个都有一个DrawableRight,每一个都设置了他的OnFocusChangeListener,然后在他获得焦点并且内容不为空的时候才显示DrawableRight,这时候就出现了bug,就是在从一个EditText转到另一个EditText的时候,确实会先触发之前EditText 失去焦点的事件的再触发之后EditText获得焦点的事件。但是,最终状态却是 若最后获得焦点的EditText该显示drawable ,那么两个都显示drawable,若最后获得焦点的EditText不该显示drawable,那么两个都不显示drawable,完全不是我预期的结果。单步调试,确实每一步都走了,但是就是没达到效果。。若有大牛遇到过这种问题,请指点一下。
2、EditText 的文字变化监听事件接口,TextWatcher。
这个接口中有三个方法,分别是 beforeTextChanged、onTextChanged、afterTextChanged。分别在用户输入之前,输入时,输入后调用,详细的方法及参数剖析可以看这篇文章:http://www.picksomething.cn/?p=34
若想要在监听方法里面改变输入的值,需要注意一下好几点(都非常的小,但都非常重要):
1)EditText 有一个Selection参数,这个参数设置的是EditText 中焦点在文字的什么位置,即从哪个位置开始编辑文字的。
2)若想要在TextWatcher中改变TextView 中的值,必须要先 et.removeTextChangedListener 然后设置值 et.setText("XXX"),最后在设置回去et.setTextChangedListener。否则会报数组越界的异常。
下面是我写的一个自定义的一个TextWatcher,实现的功能是 :在输入银行卡账号的时候,没输入4位数字,就会自动增加一个空格 隔开
class MyTextWatcher implements TextWatcher {
private EditText et;
private int preLength;
public MyTextWatcher(EditText et) {
this.et = et;
}
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
preLength = s.length();
}
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
}
@Override
public void afterTextChanged(Editable s) {
Drawable drawable = et_bankCardId.getCompoundDrawables()[2];
int length = s.length();
if (drawable != null) {
if (s != null && length > 0) {
//这里设置 alpha 为160 仅仅是为了让它显示的颜色稍微淡些
drawable.setAlpha(160);
} else {
drawable.setAlpha(0);
}
}
//每满足四个字符 加一个空格 或者删除一个空格
if (length == 5 || length == 10 || length == 15 || length == 20) {
if (preLength < s.length()) {
StringBuilder sb = new StringBuilder(s.toString());
sb.insert(sb.length() - 1, " ");
changeText(sb.toString(), et);
} else if (preLength > s.length()) {
changeText(s.toString().substring(0, s.length() - 1), et);
}
}
}
private void changeText(String s, EditText et) {
et.removeTextChangedListener(this);
et.setText(s);
et.setSelection(s.length());
et.addTextChangedListener(this);
}
}
这里我用了preLength来区别,用户将要的操作是删除 还是写入。
我建议不要在beforeTextChanged方法里面来改文本内容,因为就算你删除了监听,又设置了监听,他还是会继续调用 onTextChanged 方法和 afterTextChanged方法,那你也肯定在这两个方法里面也改变文本的内容,这样一来是非常不好判断逻辑的。
3、EditText 设置当文本输入不合法时的error和 小动画
4、酷炫的EditText
5、EditText 焦点问题(比如说在ListView中)