Android 在显示使用 nextFocusDown 设置的键盘后切换 Fragment 时应用崩溃

Android app crashes when switching Fragment after showing a keyboard that is set with nextFocusDown

我有一个应用程序可以很好地处理基于导航栏交互切换的多个片段。 其中一个屏幕有多个文本字段,我决定对这些字段进行排序,这样键盘 "next" 会自动将用户带到下一个可填写的文本字段,方法是使用 nextFocusDown。最后一个导致显示 "done" 按钮的 RadioGroup

字段看起来像这样(它们在 LinearLayout 中,在 NestedScrollView 中,在另一个 LinearLayout 中,在根 FrameLayout 下):

<EditText
    android:id="@+id/firstName"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:ems="10"
    android:inputType="textPersonName|textCapWords"
    android:nextFocusDown="@id/lastName"
    android:text="" />
<EditText
    android:id="@+id/lastName"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:ems="10"
    android:inputType="textPersonName|textCapWords"
    android:nextFocusDown="@id/email"
    android:text="" />
<EditText
    android:id="@+id/email"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:ems="10"
    android:inputType="textEmailAddress"
    android:nextFocusDown="@id/localId"
    android:text="" />

还有很多字段,有些包括文本提示等。

如果我 运行 应用程序,选择一个字段,然后点击 "next" 按钮直到键盘自行消失 - 一切正常。 当我选择一个字段时出现问题,键盘出现,我点击 android 向下按钮导致键盘消失。 这样做之后,这个屏幕上的一切看起来都很好,一切正常,直到我切换了一个片段,然后应用程序崩溃了,我在日志中看到这些错误:

04-10 00:12:24.763 redacted E/AndroidRuntime: FATAL EXCEPTION: main
    Process: redacted, PID: 24660
    java.lang.NullPointerException: Attempt to invoke interface method 'void android.view.inputmethod.InputConnection.closeConnection()' on a null object reference
        at android.view.inputmethod.InputConnectionWrapper.closeConnection(InputConnectionWrapper.java:270)
        at com.android.internal.view.IInputConnectionWrapper.executeMessage(IInputConnectionWrapper.java:541)
        at com.android.internal.view.IInputConnectionWrapper$MyHandler.handleMessage(IInputConnectionWrapper.java:85)
        at android.os.Handler.dispatchMessage(Handler.java:106)
        at android.os.Looper.loop(Looper.java:164)
        at android.app.ActivityThread.main(ActivityThread.java:6494)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:438)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:807)
04-10 00:12:24.769 redacted E/UncaughtException: java.lang.NullPointerException: Attempt to invoke interface method 'void android.view.inputmethod.InputConnection.closeConnection()' on a null object reference
        at android.view.inputmethod.InputConnectionWrapper.closeConnection(InputConnectionWrapper.java:270)
        at com.android.internal.view.IInputConnectionWrapper.executeMessage(IInputConnectionWrapper.java:541)
        at com.android.internal.view.IInputConnectionWrapper$MyHandler.handleMessage(IInputConnectionWrapper.java:85)
        at android.os.Handler.dispatchMessage(Handler.java:106)
        at android.os.Looper.loop(Looper.java:164)
        at android.app.ActivityThread.main(ActivityThread.java:6494)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:438)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:807)

知道发生了什么以及如何避免吗?

P.S.
因为我很确定它与 nextFocusOn 和键盘有关,所以我没有 post 更多(这是一个相当大的文件),如果您认为还需要什么,请告诉我,我会上传相关部分。

我今天也遇到了那个错误。我不确定它是否对您的情况有帮助,但对我有帮助。基于本主题中的答案:.

在我的例子中,禁用高级分析就足够了

运行 --> 编辑配置 --> 分析选项卡

在我的例子中,错误发生在将导体控制器从一个带有输入的控制器更改为另一个之后。错误是完全一样的。与相关 link 相同,我今天将 AS 更新为 3.1.1。

为我解决问题的是:

  1. 清理构建(构建->清理项目)
  2. 退出Android工作室
  3. 重新启动 android 设备
  4. 启动 Android Studio(设备启动后)
  5. 运行

我不知道为什么它为我解决了这个问题(我主要为 iOS 编写应用程序,而且我从未遇到过需要重启设备的错误...)。 奇怪的是,我重新启动了设备 Android Studio,并多次清理项目 - 所以看起来整个过程必须按此顺序...

由于零原因,上述解决方案均无效。出于零原因,在我的设备旁边启动模拟器并同时在两者上启动应用程序解决了这个问题。

这没有任何意义,谁做了这个废话就欠我一个小时。

如果这解决了问题,我希望能节省别人的时间。

我在使用 Android 架构组件中的导航时遇到了同样的错误,它在内部使用了片段事务。 问题是 EditText 在事务之前有文本,并且由于某种原因 Android 框架崩溃了。

解决方案是在进行交易之前将所有 EditText 设置为 null