Resposta curta
Você pode verificar qual Visualização tem o foco atualmente para distinguir entre os eventos disparados pelo usuário e pelo programa.
EditText myEditText = (EditText) findViewById(R.id.myEditText);
myEditText.addTextChangedListener(new TextWatcher() {
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
if (myEditText.hasFocus()) {
// is only executed if the EditText was directly changed by the user
}
}
//...
});
Resposta longa
Como complemento à resposta curta: Caso myEditText
já tenha o foco quando você alterar programaticamente o texto que deve chamar clearFocus()
, então você liga setText(...)
e depois pede novamente o foco. Seria uma boa ideia colocar isso em uma função de utilidade:
void updateText(EditText editText, String text) {
boolean focussed = editText.hasFocus();
if (focussed) {
editText.clearFocus();
}
editText.setText(text);
if (focussed) {
editText.requestFocus();
}
}
Para Kotlin:
Como o Kotlin oferece suporte a funções de extensão, sua função de utilitário pode ser parecida com esta:
fun EditText.updateText(text: String) {
val focussed = hasFocus()
if (focussed) {
clearFocus()
}
setText(text)
if (focussed) {
requestFocus()
}
}