Я использую TextInputEditText
с databinding
- до недавнего времени он работал нормально.Вот один из макетов, в которых возникла эта проблема:
<android.support.design.widget.TextInputLayout
android:id="@+id/new_pass_confirm"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="16dp"
android:hint="@string/new_pass_confirm_hint"
app:errorEnabled="true"
app:passwordToggleEnabled="true">
<android.support.design.widget.TextInputEditText
android:id="@+id/new_pass_confirm_et"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:enabled="@{viewmodel.enabled && !viewmodel.progress}"
android:imeOptions="actionDone"
android:inputType="textPassword"
android:maxLines="1"
android:text="@={viewmodel.newPassConfirm}"
android:textSize="18sp" />
</android.support.design.widget.TextInputLayout>
Но теперь, когда пользователь пытается что-то ввести, приложение зависает и logcat
снова и снова заполняется повторяющимися сообщениями:
V/InputMethodManager: Starting input: tba=android.view.inputmethod.EditorInfo@ccaf106 nm : package.my ic=com.android.internal.widget.EditableInputConnection@87ca3c7
I/InputMethodManager: startInputInner - mService.startInputOrWindowGainedFocus
V/InputMethodManager: Starting input: tba=android.view.inputmethod.EditorInfo@e26ddb nm : package.my ic=com.android.internal.widget.EditableInputConnection@43b078
I/InputMethodManager: startInputInner - mService.startInputOrWindowGainedFocus
V/InputMethodManager: Starting input: tba=android.view.inputmethod.EditorInfo@4fff78e nm : package.my ic=com.android.internal.widget.EditableInputConnection@43ddbaf
I/InputMethodManager: startInputInner - mService.startInputOrWindowGainedFocus
W/IInputConnectionWrapper: getCursorCapsMode on inactive InputConnection
Проблема исчезает, если я удаляю android:text="@={viewmodel.newPassConfirm}"
Похоже, проблема в том, что val newPassConfirm = ObservableField("")
пытается изменить xml-поле в бесконечном цикле
Это работало отлично до нескольких дней назад. Что я пробовал:
удаление android:imeOptions="actionDone"
удаление android:inputType="textPassword"
удалено каждое из нижеследующего изслой представления:
binding.newPassConfirm.setOnClickListener(v -> binding.newPassConfirm.setError(null));
binding.newPassConfirmEt.addTextChangedListener(new DefaultTextWatcher() {
@Override
public void afterTextChanged(Editable s) {
binding.newPassConfirm.setError(null);
}
});
binding.newPassConfirmEt.setOnEditorActionListener(
(v, actionId, event) -> {
if (actionId == EditorInfo.IME_ACTION_DONE
|| event.getAction() == KeyEvent.ACTION_DOWN
&& event.getKeyCode() == KeyEvent.KEYCODE_ENTER) {
mViewModel.onOkClick();
return true;
}
return false;
});