TextInputEditText зависает при вводе с привязкой данных

Я использую 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 &amp;&amp; !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;
                    });
    

person ildar ishalin    schedule 12.12.2018    source источник


Ответы (2)


Причиной ошибки был этот метод в DataBindingAdapter

@BindingAdapter("android:text")
public static void setText(TextView textView, String text) {
    textView.setText(text != null ? text : "");
}

Он может зацикливаться с кодом привязки данных, что приводит к значительным задержкам.

person ildar ishalin    schedule 12.12.2018

Добавление inputType="textPhonetic" в XML решило мою проблему:

android:inputType="textPhonetic"

Не уверен, какой тип ввода вызывает эту задержку. Потратил на это свой день!

person Ibrahim Broachwala    schedule 19.11.2019