Сейчас я обрабатываю ключ ввода в своих полях EditText, используя onEditorActionListener и просматривая идентификатор действия для IME_NULL. Он отлично работает для всех моих пользователей, кроме одного. У нее есть Xperia Arc.
TextView.OnEditorActionListener keyListener = new TextView.OnEditorActionListener(){
public boolean onEditorAction(TextView view, int actionId, KeyEvent event) {
if(actionId == EditorInfo.IME_NULL){
if(((EditText)findViewById(view.getId())) == ((EditText)findViewById(R.id.etUser))){
((EditText) findViewById(R.id.etPass)).requestFocus();
}
if(((EditText)findViewById(view.getId())) == ((EditText)findViewById(R.id.etPass))){
logon();
}
}
return true;
}
};
Узнав о проблеме, я попробовал другой подход, используя onKeyListener и ищет ключевое событие ACTION_DOWN, а затем проверяет код ключа, если он соответствует KEYCODE_ENTER.
EditText etUserName = (EditText) findViewById(R.id.etUser);
etUserName.setOnKeyListener(new OnKeyListener() {
public boolean onKey(View view, int keyCode, KeyEvent event){
if (event.getAction() == KeyEvent.ACTION_DOWN){
switch (keyCode)
{
case KeyEvent.KEYCODE_DPAD_CENTER:
case KeyEvent.KEYCODE_ENTER:
if(((EditText)findViewById(view.getId())) == ((EditText)findViewById(R.id.etUser))){
((EditText) findViewById(R.id.etPass)).requestFocus();
}
return true;
default:
break;
}
}
return false;
}
});
Никаких кубиков тоже. Сейчас я в недоумении. Существует множество приложений, которые отлично обрабатывают ключ ввода. что они делают по-другому?