我知道以前有人问过这个/类似的问题,但是给出的解决方案对我没有用,所以我再问一次。我尝试了在这个答案中给出的解决方案,但是我的OnKeyListener从未在某些设备上被调用,特别是那些带有股票操作系统的设备。当editText中没有字符时,我需要检测软键盘的del键的按压。这是我的密码;
EditText et = (EditText) findViewById(R.id.et);
et.setOnKeyListener(new EditText.OnKeyListener() {
@Override
public boolean onKey(View v, int keyCode, KeyEvent event) {
Log.d("OnKeyListener", keyCode + " character(code) to send");
return false;
}
});发布于 2014-07-08 06:08:03
最后,通过TextWatcher实现了这一特性。主要的障碍是,即使在EditText中没有字符,或者至少最终用户认为没有字符时,我也需要检测退空间压力。第一件事是做不到的,但是我做了后一件。以下是详细的解决方案。
首先,我总是在我的editText中保留一个空格‘字符。
editText.addTextChangedListener(new TextWatcher() {
@Override
public void onTextChanged(CharSequence cs, int arg1, int arg2, int arg3) {
if(cs.toString().length() == 0)
editText.setText(" ");
}
@Override
public void beforeTextChanged(CharSequence arg0, int arg1, int arg2, int arg3) { }
@Override
public void afterTextChanged(Editable arg0) { }
});然后,我定制了EditText,以便在每次光标位置变化时通知我。这是通过重写EditText的EditText方法来实现的。我定制的EditText看起来是这样的。
public class SelectionEnabledEditText extends EditText {
public SelectionEnabledEditText(Context context) {
super(context);
}
public SelectionEnabledEditText(Context context, AttributeSet attrs) {
super(context, attrs);
}
public SelectionEnabledEditText(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
}
@Override
protected void onSelectionChanged(int selStart, int selEnd) {
super.onSelectionChanged(selStart, selEnd);
if(onSelectionChangeListener != null)
onSelectionChangeListener.onSelectionChanged(selStart, selEnd);
}
public static interface OnSelectionChangeListener{
public void onSelectionChanged(int selStart, int selEnd);
}
private OnSelectionChangeListener onSelectionChangeListener;
public void setOnSelectionChangeListener(OnSelectionChangeListener onSelectionChangeListener) {
this.onSelectionChangeListener = onSelectionChangeListener;
}
}最后,在我的活动中,我正在监听光标位置更改事件,并在editText中重置光标位置,如果它在必要的空格字符启动处,即在第0索引处,如下所示;
editText.setOnSelectionChangeListener(new SelectionEnabledEditText.OnSelectionChangeListener() {
@Override
public void onSelectionChanged(int selStart, int selEnd) {
if (selEnd == 0) {
if (editText.getText().toString().length() == 0)
editText.setText(" ");
editText.setSelection(1);
}
}
});希望这在类似情况下会有所帮助。欢迎关于改进/优化的建议。
发布于 2014-06-26 08:38:56
文档指出,关键事件只会传播给硬件键笔画,而不是软件。
http://developer.android.com/reference/android/view/View.OnKeyListener.html
实际上,设备制造商被劝阻通过键侦听器来传播软键盘事件,尽管完全取决于制造商是否遵守这一标准,或者实际上以平等的方式对待软键盘和硬键盘。
从Android4.2.2开始,Android系统本身将根本不支持软键盘的关键刺激事件,因此即使是制造商也无法选择他们的方式。
因此,这里唯一的万无一失的选择是实现您自己的IME (软键盘),并自己处理击键。
TextWatcher主要用于替换键侦听器,但是editText.setText(.)也会触发TextWatcher事件,因此如果只对键入的键感兴趣,那么TextWatcher也可能不是解决方案。
在使用TextWatcher和AutocomleteTextView或EditText时,请小心。不要从AutocompleteTextView /EditText的内容中从TextWatcher事件中修改文本,否则很可能会出现无限事件/侦听循环。
发布于 2014-06-26 08:48:37
基于文档的OnKeyListener,回调似乎只对硬件键盘调用。
在将硬件键事件分派到此视图时调用回调的接口定义。在将键事件交给视图之前,将调用回调。这仅对硬件键盘有用;软件输入方法没有义务触发此侦听器。
https://stackoverflow.com/questions/24425838
复制相似问题