在Activity的onCreate生命周期里执行下列代码,导致 xxx does not have a NavController set on xxx 报错

I/art: Do partial code cache collection, code=57KB, data=58KB
I/art: After code cache collection, code=53KB, data=56KB
I/art: Increasing code cache capacity to 256KB
D/AndroidRuntime: Shutting down VM
E/AndroidRuntime: FATAL EXCEPTION: mainProcess: com.zjm.myapplication, PID: 6291java.lang.RuntimeException: Unable to start activity ComponentInfo{com.zjm.myapplication/com.zjm.myapplication.footNavigation.FootNavActivity}: java.lang.IllegalStateException: Activity com.zjm.myapplication.footNavigation.FootNavActivity@23141b0 does not have a NavController set on 2131230967at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2668)at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2729)at android.app.ActivityThread.-wrap12(ActivityThread.java)at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1480)at android.os.Handler.dispatchMessage(Handler.java:102)at android.os.Looper.loop(Looper.java:154)at android.app.ActivityThread.main(ActivityThread.java:6176)at java.lang.reflect.Method.invoke(Native Method)at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:893)at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:783)Caused by: java.lang.IllegalStateException: Activity com.zjm.myapplication.footNavigation.FootNavActivity@23141b0 does not have a NavController set on 2131230967at androidx.navigation.Navigation.findNavController(Navigation.java:61)at com.zjm.myapplication.footNavigation.FootNavActivity.onCreate(FootNavActivity.java:28)at android.app.Activity.performCreate(Activity.java:6692)at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1118)at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2621)at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2729) at android.app.ActivityThread.-wrap12(ActivityThread.java) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1480) at android.os.Handler.dispatchMessage(Handler.java:102) at android.os.Looper.loop(Looper.java:154) at android.app.ActivityThread.main(ActivityThread.java:6176) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:893) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:783)

布局:

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"xmlns:tools="http://schemas.android.com/tools"android:id="@+id/activity_foot_main"android:layout_width="match_parent"android:layout_height="match_parent"tools:context=".footNavigation.FootNavActivity"><com.google.android.material.bottomnavigation.BottomNavigationViewandroid:id="@+id/bottomNavigationView"android:layout_width="match_parent"android:layout_height="wrap_content"app:layout_constraintBottom_toBottomOf="parent"app:layout_constraintEnd_toEndOf="parent"app:layout_constraintStart_toStartOf="parent"app:menu="@menu/menu_foot_nav" /><androidx.fragment.app.FragmentContainerViewandroid:id="@+id/fragmentContainerView2"android:name="androidx.navigation.fragment.NavHostFragment"android:layout_width="match_parent"android:layout_height="0dp"app:defaultNavHost="true"app:layout_constraintBottom_toTopOf="@+id/bottomNavigationView"app:layout_constraintEnd_toEndOf="parent"app:layout_constraintStart_toStartOf="parent"app:layout_constraintTop_toTopOf="parent"app:navGraph="@navigation/nav_graph_foot" /></androidx.constraintlayout.widget.ConstraintLayout>

代码:

    @Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);binding = ActivityFootNavBinding.inflate(getLayoutInflater());setContentView(binding.getRoot());BottomNavigationView bottomNavigationView = findViewById(R.id.bottomNavigationView);NavController navController = Navigation.findNavController(this,R.id.fragmentContainerView2);AppBarConfiguration appBarConfiguration = new AppBarConfiguration.Builder(navController.getGraph()).build();NavigationUI.setupActionBarWithNavController(this,navController,appBarConfiguration);NavigationUI.setupWithNavController(bottomNavigationView,navController);}

问题原因

问题原因就是在onCreate生命周期里FragmentContainerView对应的NavController未构建成功.

方式一:

很简单直接onStart生命周期里获取NavController,如下代码:

    @Overrideprotected void onStart() {super.onStart();navController = Navigation.findNavController(this,R.id.fragmentContainerView2);}

或者,将获取NavController的任务放到view创建测绘完成后在执行

        mBinding.fragment.post(new Runnable() {@Overridepublic void run() {navController = Navigation.findNavController(this,R.id.fragmentContainerView2);}});

方式二:

使用getSupportFragmentManager获取

    @Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);binding = ActivityFootNavBinding.inflate(getLayoutInflater());setContentView(binding.getRoot());BottomNavigationView bottomNavigationView = findViewById(R.id.bottomNavigationView);NavHostFragment navHostFragment = (NavHostFragment)getSupportFragmentManager().findFragmentById(R.id.fragmentContainerView2);NavController navController = navHostFragment.getNavController();AppBarConfiguration appBarConfiguration = new AppBarConfiguration.Builder(navController.getGraph()).build();NavigationUI.setupActionBarWithNavController(this,navController,appBarConfiguration);NavigationUI.setupWithNavController(bottomNavigationView,navController);}

Android开发 报错: xxx does not have a NavController set on xxx相关推荐

  1. the android emulator process,Android studio报错:The emulator process for AVD (xxx) was killed

    背景:重做系统后重新配置Android studio 安装虚拟机后无法启动 log中显示为启动AVD的进程被杀 控制台显示为:在虚拟机列表里没有找到所要启动的AVD的名称 首先考虑是BIOS问题:发现 ...

  2. android override报错,android @override 报错解决方案

    android @override 报错解决方案 现象: ... java: 1801: method does not override a method from its superclass @ ...

  3. 打开Android Studio报错required plugin “Android Support” is disabled

    打开Android Studio报错 Plugin Error: required plugin "Android Support" is disabled 更详细的错误信息如下: ...

  4. Eclipse新建Android项目报错解决方案详细汇总

    本文记录刚接触Android开发搭建环境后新建工程各种可能的报错,并亲身经历漫长的解决过程(╥╯^╰╥),寻找各种偏方,避免大家采坑,希望能帮助到大家. 报错信息 出错一:The import and ...

  5. Android Studio报错:E/EGL_emulation: tid 3197: eglSurfaceAttrib(1199): error 0x3009 (EGL_BAD_MATCH)

    @[toc](Android Studio报错:E/EGL_emulation: tid 3197: eglSurfaceAttrib(1199): error 0x3009 (EGL_BAD_MAT ...

  6. 报错java找不到符号 符号:类xxx位置xxxx

    springboot开发项目 报错报错java找不到符号 符号:类xxx位置xxxx 先maven clean 然后继续报错class path resource [logback-admin.xml ...

  7. 【安卓开发/报错Error inflating class <unknown>】

    [安卓开发/报错Error inflating class ] 报错Error inflating class <unknown> 错误列表 思路 小知识 总结 报错Error infla ...

  8. access中的android sdk,Android Studio报错unable to access android sdk add-on list解决方案

    一.问题 初次安装Android Studio,启动后,报错如下: unable to access android sdk add-on lis 如图: 二.原因 AS启动后,会在默认路径下检测是否 ...

  9. Android各种报错问题汇总

    一.Android调试中报错:Could not connect to remote process. Aborting debug session. 在AndroidManifext.xml中的添加 ...

最新文章

  1. UE4风格化场景设计入门指南 Stylized Station – The Environment Artist’s Survival Kit
  2. 35.2. Subversion 版本控制
  3. 大道至简:软件工程实践者的思想——第七、八章感想
  4. ad输出光绘文件_90%的工程师容易忽视(一):PCB输出gerber文件,这样操作才正确!...
  5. mysql索引及sql执行顺序
  6. 蓝桥杯 BASIC-22 基础练习 FJ的字符串
  7. 枚举也能直接转换为对应的数值输出
  8. JavaScript—常见设计模式整理(27)
  9. 常见电平信号、RS232与RS485相关知识总结
  10. 【PS CS6】替换证件照背景色
  11. antd tooltip 修改样式
  12. 如何安全删除电脑上的个人信息和隐私资料
  13. 深信服:Weblogic集群负载均衡技术解决方案
  14. Tunnello安装指南
  15. 刷题记录(NC235611 牛牛国的战争,NC23803 DongDong认亲戚,NC235622 叠积木)
  16. vue.runtime.esm.js?2b0e:619 [Vue warn]: Avoid mutating a prop
  17. 2022年最新遥感类期刊JCR影响因子及分区
  18. [多-元-智-能]理论 IQ智商 EQ情商 AQ逆商 FQ财商 HQ健商 BQ戆商 CQ创商 MQ德商 DQ胆商 MQ心商 WQ志商 SQ灵商...
  19. 关于Omnipeek遇到“试图执行的操作不受支持”问题
  20. windows蓝屏错误小全

热门文章

  1. [黑马IOS自学第九篇]OC语言基础,面向对象概念,类的创建,OC多文件开发等
  2. 多元标量函数、矢量函数之间的关系
  3. Mysql面试常问的问题
  4. 2021-07-28 关于软件测试从业人员的几个误解
  5. 优化案例2:select标量子查询且主查询排序
  6. 中国 省级 单位 的 字母 简称 和 字母 排列 顺序
  7. jupyter notebook / jupyter lab 深色主题下如何设置字体 及 如何设置绘图颜色
  8. uni-app 小程序上下滑动问题的解决
  9. 免费在线一键领取饿了么手气最佳红包方法
  10. win10系统180天试用到期需要激活