Respostas:
Você faz isso definindo um OnKeyListener
em seu EditText
.
Aqui está um exemplo do meu próprio código. Eu tenho um EditText
nome addCourseText
, que irá chamar a função addCourseFromTextBox
quando a tecla Enter ou o d-pad for clicado.
addCourseText = (EditText) findViewById(R.id.clEtAddCourse);
addCourseText.setOnKeyListener(new OnKeyListener()
{
public boolean onKey(View v, int keyCode, KeyEvent event)
{
if (event.getAction() == KeyEvent.ACTION_DOWN)
{
switch (keyCode)
{
case KeyEvent.KEYCODE_DPAD_CENTER:
case KeyEvent.KEYCODE_ENTER:
addCourseFromTextBox();
return true;
default:
break;
}
}
return false;
}
});
android:inputType="text"
xml para o texto de edição para mostrar a tecla Enter versus o teclado padrão que tem um retorno de carro.
<EditText
android:id="@+id/search"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:hint="@string/search_hint"
android:inputType="text"
android:imeOptions="actionSend" />
Você pode, então, ouvir pressionamentos no botão de ação, definindo um TextView.OnEditorActionListener para o elemento EditText. Em seu ouvinte, responda à ID de ação IME apropriada definida na classe EditorInfo, como IME_ACTION_SEND. Por exemplo:
EditText editText = (EditText) findViewById(R.id.search);
editText.setOnEditorActionListener(new OnEditorActionListener() {
@Override
public boolean onEditorAction(TextView v, int actionId, KeyEvent event) {
boolean handled = false;
if (actionId == EditorInfo.IME_ACTION_SEND) {
sendMessage();
handled = true;
}
return handled;
}
});
Fonte: https://developer.android.com/training/keyboard-input/style.html
pode ser que você possa adicionar um atributo ao seu EditText como este:
android:imeOptions="actionSearch"
android:inputType="text"
bem
Também podemos usar Kotlin lambda
editText.setOnKeyListener { _, keyCode, keyEvent ->
if (keyEvent.action == KeyEvent.ACTION_DOWN && keyCode == KeyEvent.KEYCODE_ENTER) {
Log.d("Android view component", "Enter button was pressed")
return@setOnKeyListener true
}
return@setOnKeyListener false
}
Para evitar que o foco avance para o próximo campo editável (se você tiver um), você pode ignorar os eventos de tecla para baixo, mas lidar com eventos de tecla para cima. Também prefiro filtrar primeiro no keyCode, supondo que seja um pouco mais eficiente. A propósito, lembre-se de que retornar true significa que você manipulou o evento, portanto nenhum outro ouvinte o fará. Enfim, aqui está minha versão.
ETFind.setOnKeyListener(new OnKeyListener()
{
public boolean onKey(View v, int keyCode, KeyEvent event)
{
if (keyCode == KeyEvent.KEYCODE_DPAD_CENTER
|| keyCode == KeyEvent.KEYCODE_ENTER) {
if (event.getAction() == KeyEvent.ACTION_DOWN) {
// do nothing yet
} else if (event.getAction() == KeyEvent.ACTION_UP) {
findForward();
} // is there any other option here?...
// Regardless of what we did above,
// we do not want to propagate the Enter key up
// since it was our task to handle it.
return true;
} else {
// it is not an Enter key - let others handle the event
return false;
}
}
});
este é um exemplo de um dos meus aplicativos como eu lido
//searching for the Edit Text in the view
final EditText myEditText =(EditText)view.findViewById(R.id.myEditText);
myEditText.setOnKeyListener(new View.OnKeyListener() {
public boolean onKey(View v, int keyCode, KeyEvent event) {
if (event.getAction() == KeyEvent.ACTION_DOWN)
if ((keyCode == KeyEvent.KEYCODE_DPAD_CENTER) ||
(keyCode == KeyEvent.KEYCODE_ENTER)) {
//do something
//true because you handle the event
return true;
}
return false;
}
});
A maneira mais atualizada de conseguir isso é:
Adicione ao seu EditText em XML:
android:imeOptions="actionSearch"
Em seguida, em sua atividade / fragmento:
EditText.setOnEditorActionListener { _, actionId, _ ->
if (actionId == EditorInfo.IME_ACTION_SEARCH) {
// Do what you want here
return@setOnEditorActionListener true
}
return@setOnEditorActionListener false
}