使用 NavController 从片段导航到另一个片段

     2023-04-18     49

关键词:

【中文标题】使用 NavController 从片段导航到另一个片段【英文标题】:Navigate from fragment to another using NavController 【发布时间】:2021-05-02 20:21:42 【问题描述】:

我正在尝试应用我看到的关于带有片段和 MVVM“新组件”的导航抽屉活动的课程,在这个简单的应用程序中,我尝试使用三个片段在它们之间导航 navController.addOnDestinationChangedListener 并显示toast消息,但似乎代码不起作用,我不知道原因

这是我的代码

public class MainActivity extends AppCompatActivity 

    private AppBarConfiguration mAppBarConfiguration;

    @Override
    protected void onCreate(Bundle savedInstanceState) 
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        Toolbar toolbar = findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);
        FloatingActionButton fab = findViewById(R.id.fab);

        FragmentManager fragmentManager = getSupportFragmentManager();
        FragmentTransaction fragmentTransaction = 
        fragmentManager.beginTransaction();

        fab.setOnClickListener(new View.OnClickListener() 
            @Override
            public void onClick(View view) 
                Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG)
                        .setAction("Action", null).show();
            
        );
        DrawerLayout drawer = findViewById(R.id.drawer_layout);
        NavigationView navigationView = findViewById(R.id.nav_view);
        // Passing each menu ID as a set of Ids because each
        // menu should be considered as top level destinations.
        mAppBarConfiguration = new AppBarConfiguration.Builder(
                R.id.nav_home, R.id.nav_gallery, R.id.nav_slideshow)
                .setDrawerLayout(drawer)
                .build();
        NavController navController = Navigation.findNavController(this, R.id.nav_host_fragment);
        NavigationUI.setupActionBarWithNavController(this, navController, mAppBarConfiguration);
        NavigationUI.setupWithNavController(navigationView, navController);

        navController.addOnDestinationChangedListener(new NavController.OnDestinationChangedListener() 
            @Override
            public void onDestinationChanged(@NonNull NavController controller, @NonNull NavDestination destination, @Nullable Bundle arguments) 

                int menuId = destination.getId();
                switch (menuId)
                    case R.id.nav_gallery:
                        fab.hide();
                        Toast.makeText(getApplicationContext(),"Gallery",Toast.LENGTH_LONG).show();
                        fragmentTransaction.replace(R.id.homeFragment,new GalleryFragment());
                        fragmentTransaction.addToBackStack(null);
                        fragmentTransaction.commit();

                        NavGraph navGraph = new NavGraph()

//                        controller.getGraph().clear();
//                        controller.navigate(R.id.nav_gallery);


                        break;
                    case R.id.nav_slideshow:
                        fab.hide();
                        Toast.makeText(getApplicationContext(),"Slideshow",Toast.LENGTH_LONG).show();
                        break;


                

            
        );

    

    @Override
    public boolean onCreateOptionsMenu(Menu menu) 
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.main, menu);
        return true;
    

    @Override
    public boolean onSupportNavigateUp() 
        NavController navController = Navigation.findNavController(this, R.id.nav_host_fragment);
        return NavigationUI.navigateUp(navController, mAppBarConfiguration)
                || super.onSupportNavigateUp();
    

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<androidx.drawerlayout.widget.DrawerLayout 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/drawer_layout"
    android:layout_
    android:layout_
    android:fitsSystemWindows="true"
    tools:openDrawer="start">

    <com.google.android.material.navigation.NavigationView
        android:id="@+id/nav_view"
        android:layout_
        android:layout_
        android:layout_gravity="start"
        android:fitsSystemWindows="true"
        app:headerLayout="@layout/nav_header_main"
        app:menu="@menu/activity_main_drawer" />

    <include
        layout="@layout/app_bar_main"
        android:layout_
        android:layout_ />
</androidx.drawerlayout.widget.DrawerLayout>

content.main.xml

<?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:layout_
    android:layout_
    app:layout_behavior="@string/appbar_scrolling_view_behavior"
    tools:showIn="@layout/app_bar_main">

    <fragment
        android:id="@+id/nav_host_fragment"
        android:name="androidx.navigation.fragment.NavHostFragment"
        android:layout_
        android:layout_
        app:defaultNavHost="true"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:navGraph="@navigation/mobile_navigation" />
</androidx.constraintlayout.widget.ConstraintLayout>

mobile_navigation.xml

<?xml version="1.0" encoding="utf-8"?>
<navigation 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/mobile_navigation"
    app:startDestination="@+id/nav_home">

    <fragment
        android:id="@+id/nav_home"
        android:name="com.test.dummyappv3.ui.home.HomeFragment"
        android:label="@string/menu_home"
        tools:layout="@layout/fragment_home" />

    <fragment
        android:id="@+id/nav_gallery"
        android:name="com.test.dummyappv3.ui.gallery.GalleryFragment"
        android:label="@string/menu_gallery"
        tools:layout="@layout/fragment_gallery" />

    <fragment
        android:id="@+id/nav_slideshow"
        android:name="com.test.dummyappv3.ui.slideshow.SlideshowFragment"
        android:label="@string/menu_slideshow"
        tools:layout="@layout/fragment_slideshow" />
</navigation>

在寻找解决方案时,我发现了这个answer,并尝试使用这样的控制器

controller.getGraph().clear();
controller.navigate(R.id.nav_gallery);

而不是使用片段事务,但它也不起作用

【问题讨论】:

【参考方案1】:

好的,你需要了解两件事。

    NavigationController 与 FragmentManager 没有任何共同之处,只是它也可以交换 Fragment。

    应用您的课程,您需要决定使用 FragmentManager 或 NavigationController。

同时使用这两者不仅会让自己感到困惑,而且可能会使应用程序本身崩溃。

【讨论】:

我尝试了两种方法,但没有一种方法可以工作,新方法是使用 NavigationController 我添加了这一行 Navigation.findNavController( MainActivity.this, R.id.nav_host_fragment).navigate(R.id.nav_gallery); 它应该真的可以工作,但不幸的是我可以'不知道这个项目有什么问题【参考方案2】:

这里的问题

    <include
        layout="@layout/app_bar_main"
        android:layout_
        android:layout_ />

将此包含从此处移至 NavigationView 的顶部

<?xml version="1.0" encoding="utf-8"?>
<androidx.drawerlayout.widget.DrawerLayout 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/drawer_layout"
    android:layout_
    android:layout_
    android:fitsSystemWindows="true"
    tools:openDrawer="start">

    <include
        layout="@layout/app_bar_main"
        android:layout_
        android:layout_ />

    <com.google.android.material.navigation.NavigationView
        android:id="@+id/nav_view"
        android:layout_
        android:layout_
        android:layout_gravity="start"
        android:fitsSystemWindows="true"
        app:headerLayout="@layout/nav_header_main"
        app:menu="@menu/activity_main_drawer" />



</androidx.drawerlayout.widget.DrawerLayout>

那么一切都会好起来的

【讨论】:

IllegalArgumentException:此 NavController 未知导航目的地 xxx

】IllegalArgumentException:此NavController未知导航目的地xxx【英文标题】:IllegalArgumentException:navigationdestinationxxxisunknowntothisNavController【发布时间】:2018-12-0605:31:34【问题描述】:当我尝试从一个片段导航到另一个片段时,我遇到了新... 查看详情

从通知导航到带有 NavController 的片段

】从通知导航到带有NavController的片段【英文标题】:NavigatetofragmentwithNavControllerfromnotification【发布时间】:2020-08-0807:00:24【问题描述】:当用户单击通知时,我需要导航到片段。如果应用程序正在运行,这可以正常工作。但是... 查看详情

使用导航从一个片段导航到另一个片段后,防止后按工作

】使用导航从一个片段导航到另一个片段后,防止后按工作【英文标题】:preventonbackpressedtoworkafterusingnavigationtonavigatefromonefragmenttotheother【发布时间】:2020-09-0319:14:00【问题描述】:您好,我使用导航组件和导航图从一个片段导... 查看详情

使用导航组件从一个活动导航到另一个活动

】使用导航组件从一个活动导航到另一个活动【英文标题】:NavigatefromoneactivitytoanotherwithNavigationComponent【发布时间】:2020-09-2414:40:29【问题描述】:我正在尝试从一个导航图(主机片段位于LoginActivity)导航到另一个导航图(主... 查看详情

从一页导航到另一页后脚本未加载

...njucks【发布时间】:2021-12-1818:19:04【问题描述】:我正在使用nunjucks和express创建网站,它的博客网站之王和来自prismic的内容。当用户从博客列表页面导航到任何博客详细信息页面,导航到详细信息页面后,我想为活动Campane表单... 查看详情

Android 在使用 NavController 时向上导航正确的图表

】Android在使用NavController时向上导航正确的图表【英文标题】:AndroidnavigateuptherightgraphwhenusingNavController【发布时间】:2019-08-1016:54:45【问题描述】:我目前在我的项目中使用Android导航架构。它具有可以使用快捷方式启动任何片... 查看详情

导航组件:找不到 NavController

】导航组件:找不到NavController【英文标题】:NavigationComponent:CannotfindNavController【发布时间】:2019-05-2223:18:47【问题描述】:我正在使用导航组件在我的应用程序中导航。它在片段内工作正常,但无法在包含实际导航主机的活动... 查看详情

如何使用 StreamBuilder 从一页导航到另一页

】如何使用StreamBuilder从一页导航到另一页【英文标题】:howtouseStreamBuilderfornavigationfromonepagetoanotherpage【发布时间】:2020-08-1322:58:42【问题描述】:我想检查用户的电话号码是否存在于firestre中?如果它存在于Firestore中,那么它... 查看详情

如何使用 JetpackNavigation 组件从 BottomSheetDialogFragment 导航到另一个 Fragment

】如何使用JetpackNavigation组件从BottomSheetDialogFragment导航到另一个Fragment【英文标题】:HowtonavigatefromBottomSheetDialogFragmenttoanotherFragmentusingJetpackNavigationcomponent【发布时间】:2021-11-0821:59:49【问题描述】:如果我尝试从底部工作表对... 查看详情

导航到另一条路线后如何使用 Provider?

】导航到另一条路线后如何使用Provider?【英文标题】:HowtoconsumeProviderafternavigatingtoanotherroute?【发布时间】:2020-01-1418:07:17【问题描述】:我的应用有2种用户类型:管理员和普通用户。我向管理员显示管理屏幕,向普通用户显... 查看详情

Angular 2 - 如何使用 this.router.parent.navigate('/about') 导航到另一条路线?

】Angular2-如何使用this.router.parent.navigate(\\\'/about\\\')导航到另一条路线?【英文标题】:Angular2-HowdoInavigatetoanotherrouteusingthis.router.parent.navigate(\'/about\')?Angular2-如何使用this.router.parent.navigate(\'/about\')导航到另一条路线?【发布时 查看详情

从一页到另一页的反应导航不起作用

...orking【发布时间】:2019-04-1310:18:08【问题描述】:我正在使用Reactnative为iOS和Android开发多页应用程序。我使用ReactNavigation从一页导航到另一页。但不知何故它不起作用并给出错误消息。这是我到目前为止所做的。App.jsimportReact,Com... 查看详情

我们如何在 GWT 中从一页导航到另一页

】我们如何在GWT中从一页导航到另一页【英文标题】:Howdowenavigatefrom1pagetoanotherinGWT【发布时间】:2013-07-0306:11:09【问题描述】:我正在GWT中构建一个项目,当单击按钮时,该项目需要从一个页面导航到另一个页面。我该怎么做... 查看详情

想要使用片段从导航抽屉活动移动到另一个屏幕,以在所有屏幕上显示抽屉(代码片段)

我正在尝试最后两天在我的抽屉活动旁边添加片段,以便在整个应用程序中看到导航抽屉。我已尝试过stackoverflow和其他许多方法,但仍然没有成功。然后我必须从第一个片段移动到第二个片段,依此类推,直到需要导航抽屉。... 查看详情

导航组件-模仿navcontroller图形(代码片段)

...widget.Toolbar.init(menuId:Int?=null)title=""menuId?.letinflateMenu(it)findNavController().letit.graph.letgraph->valconfiguration=AppBarConfiguration(graph)setupWithNavController(it,configuration)在我的仪器测试中,在初始化场景的过程中,由于一个叫"D"的方法,测试崩... 查看详情

Android:如何在选项卡内从一个片段导航到另一个片段? [关闭]

...项卡B的列表项时,应该在选项卡中调用一个新的片段C。使用以下代码,我可以 查看详情

如何从一个片段导航到另一个片段?

】如何从一个片段导航到另一个片段?【英文标题】:HowtonavigatefromoneFragmenttoanother?【发布时间】:2013-12-1910:44:27【问题描述】:这是我的代码:activity_main.xml<RelativeLayoutxmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="htt... 查看详情

从片段导航到另一个片段时隐藏键盘

】从片段导航到另一个片段时隐藏键盘【英文标题】:Hidekeyboardwhennavigatingfromafragmenttoanother【发布时间】:2015-01-1018:01:40【问题描述】:我有一个包含编辑文本的片段。按下编辑文本时,将显示键盘。当按下右上角的保存按钮时... 查看详情