?监听事件
setOnEditorActionListener:软键盘回车监听事件
testEditText.setOnEditorActionListener(new TextView.OnEditorActionListener() {
@Override
public boolean onEditorAction(TextView v, int actionId, KeyEvent event) {
Log.e("TAG", "onEditorAction: 点击了回车按钮");
return false;
}
});
Kotlin代码
testEditText.setOnEditorActionListener(OnEditorActionListener { v, actionId, event ->
Log.e("TAG", "onEditorAction: 点击了回车按钮")
false
})
addTextChangedListener:文本变化监听事件,里面有三个回调函数
beforeTextChanged(CharSequence s, int start, int count, int after)
参数一代表输入的字符,参数二代表当前光标所在EditText整个字符串的位置,参数三一般为0,参数四代表一次性输入了几个字符,主要是中文状态或直接粘贴上去的字符(数字或符号或英文都是点击一个就显示上去了,所以该值为1,中文一般都是打几个字显示上去)
onTextChanged(CharSequence s, int start, int before, int count)
基本同上面的说明
afterTextChanged(Editable s)
参数为修改后的字符
testEditText.addTextChangedListener(new TextWatcher() {
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
//参数1代表输入的
Log.e("TAG", "beforeTextChanged: 输入前(内容变化前)的监听回调"+s.toString()+"==="+start+"==="+count+"==="+after);
}
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
Log.e("TAG", "beforeTextChanged: 输入中(内容变化中)的监听回调"+s.toString()+"==="+start+"==="+before+"==="+count);
}
@Override
public void afterTextChanged(Editable s) {
Log.e("TAG", "beforeTextChanged: 输入后(内容变化后)的监听回调"+s.toString());
}
});
Kotlin代码
testEditText.addTextChangedListener(object : TextWatcher {
override fun beforeTextChanged(s: CharSequence, start: Int, count: Int, after: Int) {
//参数1代表输入的
Log.e("TAG", "beforeTextChanged: 输入前(内容变化前)的监听回调$s===$start===$count===$after")
}
override fun onTextChanged(s: CharSequence, start: Int, before: Int, count: Int) {
Log.e("TAG", "beforeTextChanged: 输入中(内容变化中)的监听回调$s===$start===$before===$count")
}
override fun afterTextChanged(s: Editable) {
Log.e("TAG", "beforeTextChanged: 输入后(内容变化后)的监听回调$s")
}
})
setOnFocusChangeListener:是否获取焦点的监听
testEditText.setOnFocusChangeListener(new View.OnFocusChangeListener() {
@Override
public void onFocusChange(View v, boolean hasFocus) {
Log.e("TAG", "onFocusChange: 是否获取焦点:hasFocus:为true表示获取焦点,为false表示未获取");
}
});
Kotlin代码
testEditText.setOnFocusChangeListener(OnFocusChangeListener { v, hasFocus ->
Log.e("TAG", "onFocusChange: 是否获取焦点:hasFocus:为true表示获取焦点,为false表示未获取")
})
?InputFilter
字符过滤在项目中也是经常会遇到的业务功能(比如限制输入小数点后两位,比如仅限制中文输入,比如不能输入特殊字符,再比如WOCAO等敏感词屏蔽)。
有的同学要说了,【android:inputType】不就是做这个的吗,确实,但是为了兼容大多数人,必须要有取舍,因此也就有了局限性。
系统内置了两个过滤:new InputFilter.AllCaps()和new InputFilter.LengthFilter(int max)
AllCaps为全部自动转换为大写,LengthFilter为限制字符长度最大为几。
我们【Ctrl+左键】快捷键点进去看远吗,他们是继承的【InputFilter】,所以我们也能继承继而实现自己的过滤规则。
InputFilter custemInputFiter = new InputFilter() {
@Override
public CharSequence filter(CharSequence source, int start, int end, Spanned dest, int dstart, int dend) {
//source 新输入的字符串
//start 新输入的字符串起始下标,一般为0
//end 新输入的字符串终点下标,一般为source长度-1
//dest 输入之前文本框内容
//dstart 原内容起始坐标,一般为0
//dend 原内容终点坐标,一般为dest长度-1
if (source.toString().equals("芝麻粒儿")) {
//此示例:输入的如果是【芝麻粒儿】,则直接返回null,页面上表现为不显示
return null;
}
Log.e("TAG", "filter: 自定义的过滤规则");
return null;
}
};
//传递的参数是数组,也就是可以有多个过滤规则
testEditText.setFilters(new InputFilter[]{
custemInputFiter,
new InputFilter.LengthFilter(6),
new InputFilter.AllCaps()});
Kotlin代码
val custemInputFiter = InputFilter { source, start, end, dest, dstart, dend -> //source 新输入的字符串
//start 新输入的字符串起始下标,一般为0
//end 新输入的字符串终点下标,一般为source长度-1
//dest 输入之前文本框内容
//dstart 原内容起始坐标,一般为0
//dend 原内容终点坐标,一般为dest长度-1
if (source.toString() == "芝麻粒儿") {
//此示例:输入的如果是【芝麻粒儿】,则直接返回null,页面上表现为不显示
return@InputFilter null
}
Log.e("TAG", "filter: 自定义的过滤规则")
null
}
//传递的参数是数组,也就是可以有多个过滤规则
testEditText.setFilters(
arrayOf(
custemInputFiter,
LengthFilter(6),
AllCaps()
)
)
以上就是Android开发EditText禁止输入监听及InputFilter字符过滤的详细内容,更多关于Android EditText监听InputFilter的资料请关注三水点靠木其它相关文章!
Android开发EditText禁止输入监听及InputFilter字符过滤
- Author -
芝麻粒儿- Original Sources -
声明:登载此文出于传递更多信息之目的,并不意味着赞同其观点或证实其描述。
Tags in this post...
Reply on: @reply_date@
@reply_contents@