前言
BottomSheetDialogFragment是基于DialogFragment封装的,如果你不太了解DialogFragment,可以参考另一篇博客Android开发 DialogFragment对话框详解
基本使用代码
import android.os.Bundle
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import com.google.android.material.bottomsheet.BottomSheetDialogFragment
import com.lwlx.ui.main.databinding.MainDialogSelectBinding
class MyBottomSheetDialogFragment: BottomSheetDialogFragment() {
override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
val binding = MainDialogSelectBinding.inflate(inflater)
return binding.root
}
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
super.onViewCreated(view, savedInstanceState)
}
}
显示对话框
private fun showDeleteTipsDialog(){
val dialog = MyBottomSheetDialogFragment()
dialog.show(supportFragmentManager, "a")
}
自定义DialogFragment实现底部弹出对话框
这个例子其实之前这个博客原来的内容,但是因为后续有了BottomSheetDialogFragment,所以自己实现其实没有意义了。但是保留代码可以大家一个参考,你可以举一反三实现其他位置的对话框弹出。
效果图

代码部分
dialog_bottom_single.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"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/root_layout"
android:background="@drawable/bg_while_rectangle_radius">
<TextView
android:id="@+id/left_btn"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:gravity="left|center_vertical"
android:paddingLeft="25dp"
android:paddingTop="13dp"
android:paddingBottom="13dp"
android:textColor="@color/color_181818"
android:textSize="18sp"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toLeftOf="@id/title" />
<TextView
android:id="@+id/title"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:gravity="center"
android:paddingTop="13dp"
android:paddingBottom="13dp"
android:singleLine="true"