如果在底部导航栏中选择了其他项目,如何删除 floatingActionButton 替换片段

Posted

技术标签:

【中文标题】如果在底部导航栏中选择了其他项目,如何删除 floatingActionButton 替换片段【英文标题】:How to remove floatingActionButton replaced fragment if other item is selected in bottom navigation bar 【发布时间】:2021-10-21 19:02:06 【问题描述】:

我正在处理底部导航栏,我已经替换了 floatingActionButton 的 onClickListener 上的片段,但如果选择了底部导航栏中的其他项目并且一次显示两个片段,则不会删除该片段。这是我的输出

如果底部导航栏中的其他项目被选中,我如何删除这个浮动操作按钮的帖子片段。

这是我的 activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<androidx.coordinatorlayout.widget.CoordinatorLayout  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_
tools:context=".MainActivity">


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

<com.google.android.material.floatingactionbutton.FloatingActionButton
    android:id="@+id/fab"
    android:layout_
    android:layout_
    android:contentDescription="@string/app_name"
    app:backgroundTint="@color/white"
    app:layout_anchor="@id/bottomAppBar"
    app:maxImageSize="64dp"
    app:srcCompat="@drawable/ic_baseline_add_circle_24" />

<com.google.android.material.bottomappbar.BottomAppBar
    android:id="@+id/bottomAppBar"
    android:layout_
    android:layout_
    android:background="@android:color/white"
    app:fabAlignmentMode="center"
    android:layout_gravity="bottom"
    app:contentInsetStart="0dp"
    app:fabCradleMargin="0dp"
    app:fabCradleRoundedCornerRadius="0dp"
    app:fabCradleVerticalOffset="0dp">

    <com.google.android.material.bottomnavigation.BottomNavigationView
        android:id="@+id/nav_view"
        android:layout_
        android:layout_
        app:labelVisibilityMode="labeled"
        app:menu="@menu/bottom_nav_menu" />
</com.google.android.material.bottomappbar.BottomAppBar>

 </androidx.coordinatorlayout.widget.CoordinatorLayout>

这是我的 MainActivity.java

package www.example.xchangeit;


import android.os.Bundle;
import android.os.PersistableBundle;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;

import com.google.android.material.bottomnavigation.BottomNavigationView;
import com.google.android.material.floatingactionbutton.FloatingActionButton;

import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;
import androidx.fragment.app.Fragment;
import androidx.fragment.app.FragmentTransaction;
import androidx.navigation.NavController;
import androidx.navigation.Navigation;
import androidx.navigation.ui.AppBarConfiguration;
import androidx.navigation.ui.NavigationUI;
import androidx.viewpager.widget.ViewPager;

import www.example.xchangeit.ui.post.PostFragment;

public class MainActivity extends AppCompatActivity


@Override
protected void onCreate(Bundle savedInstanceState) 
    super.onCreate(savedInstanceState);
    setContentView(R.layout.opening_page);
    ViewGroup LiView = findViewById(R.id.ViewGroup);
    LiView.setOnClickListener(new View.OnClickListener() 
        @Override
        public void onClick(View v) 
        layout();

        
    );

    ImageView imageView = findViewById(R.id.logo_imageView);
    imageView.setOnClickListener(new View.OnClickListener() 
        @Override
        public void onClick(View v) 
            layout();
        
    );


    

    private void layout()
    
        setContentView(R.layout.activity_main);
        BottomNavigationView navView = findViewById(R.id.nav_view);

        // Passing each menu ID as a set of Ids because each
        // menu should be considered as top level destinations.
        AppBarConfiguration appBarConfiguration = new AppBarConfiguration.Builder(
                R.id.navigation_home, R.id.navigation_exchange, R.id.navigation_post,R.id.navigation_chat,R.id.navigation_account)
                .build();
        NavController navController = Navigation.findNavController(this, R.id.nav_host_fragment);
        NavigationUI.setupActionBarWithNavController(this, navController, appBarConfiguration);
        NavigationUI.setupWithNavController(navView, navController);

        FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab);
        fab.setOnClickListener(new View.OnClickListener() 
            @Override
            public void onClick(View v) 
                FragmentTransaction transaction = getSupportFragmentManager().beginTransaction();
                transaction.replace(R.id.nav_host_fragment,new PostFragment());
                transaction.commit();

        );

    

   

【问题讨论】:

【参考方案1】:

您可以在加载下一个之前弹出上一个片段

getSupportFragmentManager().popBackStack();

现在,如果您需要更具体,可以执行以下操作:

getSupportFragmentManager().beginTransaction().remove(frag).commit(); 

在第二种情况下,我们保留对要删除的片段的引用。

【讨论】:

因为我的fragment是通过AppBarConfiguration appBarConfiguration = new AppBarConfiguration.Builder( R.id.navigation_home, R.id.navigation_exchange, R.id.navigation_post, R.id.navigation_chat, R.id.navigation_account)调用的所以不行,那这行代码应该写在哪里呢? 你的nav_host_fragment 是屏幕的全尺寸,所以我猜你发布的图片来自启动的PostFragment,或者有两个文本视图,或者有两个其他片段的自己的容器, 必须是 replacedadded 才能尊重。

以上是关于如果在底部导航栏中选择了其他项目,如何删除 floatingActionButton 替换片段的主要内容,如果未能解决你的问题,请参考以下文章

如何使用CSS在垂直导航栏中的联系人下方添加底部边框?

如何在底部应用栏中使用后退按钮实现导航。安卓

在底部导航栏中保存片段状态

如何在颤动的底部导航栏中添加抽屉?

想要在flutter中通过底部导航栏的总价

重新加载页面后如何突出显示导航栏中的活动菜单项