首页 > 解决方案 > 将 Android Studio 升级到北极狐后膨胀片段时出错

问题描述

我看到 Jetpack Compose 已经退出测试版,所以我想我会升级到北极狐。Compose 看起来非常高效,我想将它添加到我当前的项目中。

然而,在升级我的项目后,我除了构建错误和崩溃之外什么都没有。据我所知,它在膨胀布局时遇到问题,然后导致lateinit property not initialized error. 由于某种原因,它似乎无法识别<include>我的布局文件中的标签,或者它的<androidx.appcompat.widget.Toolbar>标签。

我在某处阅读以将 AGP 和 Gradle 版本更新到 7,但这并没有改变任何东西。其他项目无需升级即可运行,但有时升级后也会崩溃。在其他出现相同错误的项目中,它总是看起来像它位于工具栏标签的末尾。我没有对我的代码进行任何更改,只对插件版本进行了更改,所以我不知道为什么它会出现以前工作正常的问题。

我完全迷路了。我已经与 SDK 斗争了一周,但没有得到任何结果。

我唯一的选择似乎是恢复到旧的 SDK 或尝试 Bumblebee Canary 7。

activity_main.xml

<androidx.drawerlayout.widget.DrawerLayout
    android:id="@+id/drawer_layout">

    <include
        android:id="@+id/nav_host_layout"
        layout="@layout/nav_host"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:visibility="visible"/> // line 24 in activity_main.xml

    <com.google.android.material.navigation.NavigationView
        android:id="@+id/nav_view" />

</androidx.drawerlayout.widget.DrawerLayout>

导航主机.xml

<LinearLayout>

<include
    layout="@layout/view_main_app_bar"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:visibility="visible" />

<include
    layout="@layout/view_search_bar"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:visibility="gone" />

<FrameLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content">

    <fragment
        android:id="@+id/nav_host_fragment"
        android:name="androidx.navigation.fragment.NavHostFragment"
        app:defaultNavHost="true"
        app:navGraph="@navigation/navigation" /> // line 37 in nav_host.xml
</FrameLayout>

MainActivity.kt

override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)
    setTheme(R.style.Theme_MyApp_NoActionBar)
    setContentView(R.layout.activity_main)  // debug show it starts blowing up here

错误信息

E/AndroidRuntime: FATAL EXCEPTION: main
    Process: com.myapp.android, PID: 7891
    java.lang.RuntimeException: Unable to start activity ComponentInfo{com.myapp.android/com.myapp.android.MainActivity}: android.view.InflateException: Binary XML file line #24 in com.myapp.android:layout/activity_main: Binary XML file line #37 in com.myapp.android:layout/nav_host: Error inflating class fragment
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3270)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3409)
        at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:83)
        at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135)
        at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2016)
        at android.os.Handler.dispatchMessage(Handler.java:107)
        at android.os.Looper.loop(Looper.java:214)
        at android.app.ActivityThread.main(ActivityThread.java:7356)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:492)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:930)
     Caused by: android.view.InflateException: Binary XML file line #24 in com.myapp.android:layout/activity_main: Binary XML file line #37 in com.myapp.android:layout/nav_host: Error inflating class fragment
     Caused by: android.view.InflateException: Binary XML file line #37 in com.myapp.android:layout/nav_host: Error inflating class fragment
     Caused by: kotlin.UninitializedPropertyAccessException: lateinit property searchBar has not been initialized
        at com.myapp.android.MainActivity.toggleSearchBar(MainActivity.kt:193)
        at com.myapp.android.ui.tabs.FragmentListContainer.onCreateView(FragmentListContainer.kt:52)
        at androidx.fragment.app.Fragment.performCreateView(Fragment.java:2963)
        at androidx.fragment.app.FragmentStateManager.createView(FragmentStateManager.java:518)
        at androidx.fragment.app.FragmentStateManager.moveToExpectedState(FragmentStateManager.java:282)
        at androidx.fragment.app.FragmentStore.moveToExpectedState(FragmentStore.java:112)
        at androidx.fragment.app.FragmentManager.moveToState(FragmentManager.java:1647)
        at androidx.fragment.app.FragmentManager.dispatchStateChange(FragmentManager.java:3128)
        at androidx.fragment.app.FragmentManager.dispatchViewCreated(FragmentManager.java:3065)
        at androidx.fragment.app.Fragment.performViewCreated(Fragment.java:2988)
        at androidx.fragment.app.FragmentStateManager.ensureInflatedView(FragmentStateManager.java:392)
        at androidx.fragment.app.FragmentStateManager.moveToExpectedState(FragmentStateManager.java:281)
        at androidx.fragment.app.FragmentLayoutInflaterFactory.onCreateView(FragmentLayoutInflaterFactory.java:140)
        at androidx.fragment.app.FragmentController.onCreateView(FragmentController.java:135)
        at androidx.fragment.app.FragmentActivity.dispatchFragmentsOnCreateView(FragmentActivity.java:319)
        at androidx.fragment.app.FragmentActivity.onCreateView(FragmentActivity.java:298)
        at android.view.LayoutInflater.tryCreateView(LayoutInflater.java:1069)
        at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:997)
        at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:961)
        at android.view.LayoutInflater.rInflate(LayoutInflater.java:1123)
        at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java:1084)
        at android.view.LayoutInflater.rInflate(LayoutInflater.java:1126)
        at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java:1084)
        at android.view.LayoutInflater.parseInclude(LayoutInflater.java:1263)
        at android.view.LayoutInflater.rInflate(LayoutInflater.java:1119)
        at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java:1084)
E/AndroidRuntime:     at android.view.LayoutInflater.inflate(LayoutInflater.java:682)
        at android.view.LayoutInflater.inflate(LayoutInflater.java:534)
        at android.view.LayoutInflater.inflate(LayoutInflater.java:481)
        at androidx.appcompat.app.AppCompatDelegateImpl.setContentView(AppCompatDelegateImpl.java:699)
        at androidx.appcompat.app.AppCompatActivity.setContentView(AppCompatActivity.java:195)
        at com.myapp.android.MainActivity.onCreate(MainActivity.kt:51)
        at android.app.Activity.performCreate(Activity.java:7802)
        at android.app.Activity.performCreate(Activity.java:7791)
        at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1299)
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3245)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3409)
        at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:83)
        at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135)
        at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2016)
        at android.os.Handler.dispatchMessage(Handler.java:107)
        at android.os.Looper.loop(Looper.java:214)
        at android.app.ActivityThread.main(ActivityThread.java:7356)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:492)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:930)

标签: androidandroid-studio

解决方案


推荐阅读