BottomNavigationView 后面的片段中的底部工作表

Posted

技术标签:

【中文标题】BottomNavigationView 后面的片段中的底部工作表【英文标题】:Bottom Sheet in fragment behind BottomNavigationView 【发布时间】:2020-10-06 11:11:02 【问题描述】:

在我的片段中,单击按钮时我需要显示一个底部工作表对话框,但它必须从底部导航栏的后面出现。 here 已经解决了类似的问题,但是 由于一些压力,我只需要通过扩展 BottomSheetDialogFragment 来创建底部工作表。

activity_main.xml

<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_
    android:layout_>   

    <fragment
        android:id="@+id/navigationHost"
        android:name="androidx.navigation.fragment.NavHostFragment"
        android:layout_
        android:layout_
        app:defaultNavHost="true"
        app:layout_constraintBottom_toTopOf="@+id/bottomNavigation"
        app:layout_constraintTop_toTopOf="parent"
        app:navGraph="@navigation/navigation" />    

    <com.google.android.material.bottomnavigation.BottomNavigationView
        android:id="@+id/bottomNavigation"
        android:layout_
        android:layout_
        android:layout_marginStart="14dp"
        android:layout_marginEnd="14dp"
        android:layout_marginBottom="30dp"
        android:background="@drawable/bg_bottom_nav_rounded"
        app:itemIconTint="@color/selector_bottom_navigation_text"   
        app:itemTextColor="@color/selector_bottom_navigation_text"
        app:labelVisibilityMode="labeled"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintTop_toBottomOf="@id/navigationHost"
        app:menu="@menu/dashboard_navigation_menu" />

</androidx.constraintlayout.widget.ConstraintLayout>    

fragment_home.xml

<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_
    android:layout_
    android:background="@android:color/darker_gray">

    <Button
        android:id="@+id/openBottomSheet"
        android:layout_
        android:layout_
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

</androidx.constraintlayout.widget.ConstraintLayout>    

FragmentHome.kt

class FragmentHome : Fragment(R.layout.fragment_home) 
    private val binding by viewBinding(FragmentHomeBinding::bind)

    override fun onViewCreated(view: View, savedInstanceState: Bundle?) 
        super.onViewCreated(view, savedInstanceState)

        binding.openBottomSheet.setOnClickListener 
            val bottomSheetDialog: BottomSheetDialog = BottomSheetDialog()
            bottomSheetDialog.show(requireActivity().supportFragmentManager, "TEST")
            bottomSheetDialog.enterTransition
        
    
    

BottomSheetDialog.kt

  public class BottomSheetDialog extends BottomSheetDialogFragment 
        @Nullable
        @Override
        public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) 
            super.onCreateView(inflater, container, savedInstanceState);
            return inflater.inflate(R.layout.bottomsheet_login, container, false);
        

        @Override
        public void onViewCreated(@NonNull View view, @Nullable Bundle savedInstanceState) 
            super.onViewCreated(view, savedInstanceState);
        
    

更新:Screenshots

【问题讨论】:

看起来您使用了错误的片段管理器,但不确定这是否能解决您的问题。更改为:bottomSheetDialog.show(childSupportFragmentManager, "TEST") 并删除 bottomSheetDialog.enterTransition 以查看是否有帮助 @Indiana 进行了更改,但没有成功。 你能分享一下它的外观截图吗? @Indiana 我更新了截图。 啊,我明白你的意思了。我误解了。这是 BottomSheet 的正确预期行为。您可能需要查看自定义视图或其他解决方法。 【参考方案1】:

这是BottomSheetSnackbar 的常见问题,您需要在activity 上添加CoordinatorLayout 作为parent 根视图。将CoordinatorLayout 作为父母,并在其中放入您的ConstraintLayout

【讨论】:

以上是关于BottomNavigationView 后面的片段中的底部工作表的主要内容,如果未能解决你的问题,请参考以下文章

BottomNavigationView 的标题颜色为渐变

安卓。具有单一活动方法的 BottomNavigationView

BottomNavigationView - 阴影和波纹效果

如何使用 material.BottomNavigationView 设置 Jetpack 导航

BottomNavigationView 的使用

Android关于BottomNavigationView效果实现指南