android - 将 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)
解决方案
推荐阅读
- keras - Autokeras 导出的模型表现不如预期
- excel - Excel - 将每个单词的第一个字母转换为大写的函数
- c# - 如何从网页创建打开文件对话框?
- asp.net - 一个控件的事件触发所有页面控件
- python - 我可以在 __del__ 方法中使用线程名称/ID 登录吗?
- javascript - 无法限制 REST 响应中的类别,即使在“in”或“at”子句中提供了位置 [HERE Maps Places API]
- python - Pip 未被识别为内部或外部命令(即使在添加 PATH 变量之后)
- python - python子进程模块的动态输出
- python - 在单帧 Python 中用数据写入文件名
- node.js - req.query 在 nodejs 的 Http.createserver 中不起作用?