Fragment 不使用 FragmentContainerView 进行切换

问题描述 投票:0回答:2

我只是想将 bottomNavigation 与导航组件一起使用。我尝试了多种方法,但片段没有切换。仅底部导航显示的

我有一个正在运行的示例,它使用片段而不是 FragmentContainerView。但我不知道为什么它太复杂而无法使用最新的技术 仪表板活动

@AndroidEntryPoint
class DashboardActivity : PBActivity(R.layout.activity_dashboard) {
    val binding: ActivityDashboardBinding by viewbind()
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)

        val appBarConfiguration: AppBarConfiguration = AppBarConfiguration.Builder(
            R.id.rankingFragment, R.id.homeFragment, R.id.profileFragment
        ).build()

        setSupportActionBar(binding.toolbar)
        val navHostFragment =
            supportFragmentManager.findFragmentById(R.id.nav_host_fragment) as NavHostFragment
        val navController = navHostFragment.navController
        /*val navView = findViewById<BottomNavigationView>(R.id.bottom_nav)
        NavigationUI.setupWithNavController(navView,navController)*/

        ///binding.navigationBb.setupWithNavController(navController)
        ///binding.toolbar.setupWithNavController(navController,null)
        //binding.navHostFragment.s
        binding.toolbar.setupWithNavController(navController,appBarConfiguration)
        ///binding.bottomNav.setupWithNavController(navController)

        NavigationUI.setupWithNavController(binding.bottomNav, navController)
        ///NavigationUI.setupWithNavController(binding.bottomNav,navController)
    }
 }

activity_dashboard.xml

<?xml version="1.0" encoding="utf-8"?>
<layout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto">

    <data>

    </data>

    <androidx.constraintlayout.widget.ConstraintLayout
        android:layout_width="0dp"
        android:layout_height="0dp">

        <androidx.appcompat.widget.Toolbar
            android:id="@+id/toolbar"
            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintTop_toTopOf="parent">

        </androidx.appcompat.widget.Toolbar>

        <androidx.fragment.app.FragmentContainerView
            android:id="@+id/nav_host_fragment"
            android:name="androidx.navigation.fragment.NavHostFragment"
            android:layout_width="0dp"
            android:layout_height="0dp"
            app:layout_constraintLeft_toLeftOf="parent"
            app:layout_constraintRight_toRightOf="parent"
            app:layout_constraintTop_toTopOf="parent"
            app:layout_constraintBottom_toBottomOf="parent"
            app:defaultNavHost="true"
            app:navGraph="@navigation/nav_graph" />

        <com.google.android.material.bottomnavigation.BottomNavigationView
            android:id="@+id/bottom_nav"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintBottom_toBottomOf="parent"
            android:layout_width="match_parent"
            app:menu="@menu/dashboard_nav_menu"
            android:background="?android:attr/windowBackground"
            android:layout_height="wrap_content" />

    </androidx.constraintlayout.widget.ConstraintLayout>
</layout>

nav_graph.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/nav_graph"
    app:startDestination="@id/homeFragment">

    <fragment
        android:id="@+id/homeFragment"
        tools:layout="@layout/fragment_home"
        android:name="uk.co.planetbeyond.game_show_app.presentation.ui.main.fragments.HomeFragment"
        android:label="HomeFragment" />
    <fragment
        android:id="@+id/rankingFragment"
        tools:layout="@layout/fragment_ranking"
        android:name="uk.co.planetbeyond.game_show_app.presentation.ui.main.fragments.RankingFragment"
        android:label="RankingFragment" />
    <fragment
        android:id="@+id/profileFragment"
        tools:layout="@layout/fragment_profile"
        android:name="uk.co.planetbeyond.game_show_app.presentation.ui.main.fragments.ProfileFragment"
        android:label="ProfileFragment" />
</navigation>

dashboard_nav_menu.xml

 <?xml version="1.0" encoding="utf-8"?>
    <menu xmlns:android="http://schemas.android.com/apk/res/android">
    
        <item
            android:id="@+id/rankingFragment"
            android:icon="@drawable/rankings_button_selected"
            android:title="Ranking" />
        <item
            android:id="@+id/homeFragment"
            android:icon="@drawable/home_button_selected"
            android:title="@string/title_home" />
        <item
            android:id="@+id/profileFragment"
            android:icon="@drawable/profile_icon_selected"
            android:title="Profile" />
    </menu>
android fragment navigationcontroller
2个回答
0
投票

问题不在于导航组件,您的代码看起来很好;但你的主布局的大小为 0:

您需要设置根布局以匹配父级:

<androidx.constraintlayout.widget.ConstraintLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent">
...

旁注:片段将在工具栏后面绘制,因为它约束到父顶部边缘;底部也一样。

要将此约束固定到工具栏上:

FragmentContainerView
中替换:

app:layout_constraintTop_toTopOf="parent"
app:layout_constraintBottom_toBottomOf="parent"

与:

app:layout_constraintTop_toBottomOf="@+id/toolbar"
app:layout_constraintBottom_toTopOf="@+id/bottom_nav"

0
投票

我使用 AGP 8.4 kotlin 1.9.22

我通过这些步骤解决了这个问题

toml版本目录

[versions]
navVersion = "2.7.7"

[libraries]
navigation-ui = { group = "androidx.navigation", name = "navigation-ui", version.ref = "navVersion" }
navigation-dynamic-features-fragment = { module = "androidx.navigation:navigation-dynamic-features-fragment", version.ref = "navVersion" }
navigation-fragment = { group = "androidx.navigation", name = "navigation-fragment", version.ref = "navVersion" }
navigation-fragment-ktx = { module = "androidx.navigation:navigation-fragment-ktx", version.ref = "navVersion" }
navigation-ui-ktx = { module = "androidx.navigation:navigation-ui-ktx", version.ref = "navVersion" }

gradle 应用程序级别

// change ktx when your activity or fragment using kotlin
implementation libs.navigation.fragment // .ktx
implementation libs.navigation.ui // .ktx
implementation libs.navigation.dynamic.features.fragment

MainActivity

// imports
import androidx.navigation.NavController;
import androidx.navigation.Navigation;
import androidx.navigation.fragment.NavHostFragment;
import androidx.navigation.ui.AppBarConfiguration;
import androidx.navigation.ui.NavigationUI;

// onCreate
        NavHostFragment navHostFragment = (NavHostFragment) getSupportFragmentManager()
                .findFragmentById(R.id.nav_host_fragment_activity_main);
        NavController navController = navHostFragment.getNavController();
        // make the fragment switcher works
        NavigationUI.setupWithNavController(binding.navView, navController);
© www.soinside.com 2019 - 2024. All rights reserved.