BottomSheetDialogFragment,圆角背景,去除层叠,百分比设置高度

基本使用很简单:

public class FullSheetDialogFragment extends BottomSheetDialogFragment {
    private BottomSheetBehavior mBehavior;
    @Override
    public Dialog onCreateDialog(Bundle savedInstanceState)
    {
        BottomSheetDialog dialog = (BottomSheetDialog) super.onCreateDialog(savedInstanceState);
        View view = View.inflate(getContext(), R.layout.dialog_bottom_sheet, null);
        dialog.setContentView(view);
        mBehavior = BottomSheetBehavior.from((View) view.getParent());
        return dialog;
    }

    @Override
    public void onStart()
    {
        super.onStart();
        //默认全屏展开
        mBehavior.setState(BottomSheetBehavior.STATE_EXPANDED);
    }

    public void doclick(View v)
    {
        //点击任意布局关闭
        mBehavior.setState(BottomSheetBehavior.STATE_HIDDEN);
    }
}

调用BottomSheetDialogFragment展示

new FullSheetDialogFragment().show(getSupportFragmentManager(), "dialog");

下面是一些坑。


dialog按屏幕高度百分比调整大小:

BottomSheetDialog dialog = (BottomSheetDialog) super.onCreateDialog(savedInstanceState); mContext = getContext(); 
View view = View.inflate(mContext, R.layout.dialog_bottom_sheet1, null); dialog.setContentView(view); 
ViewGroup.LayoutParams layoutParams = view.getLayoutParams(); 
int height = (int) (mContext.getResources().getDisplayMetrics().heightPixels * 0.9); layoutParams.height = height; 
view.setLayoutParams(layoutParams);

去除层叠显示(就是去掉完全展开,中间状态,隐藏中的中间状态):

//height就是整个dialog的高度,同上面的height。如果设置为0也可以实现效果,但会导致滑动关闭后,有一层阴影遮罩,
//需要点击一次才能消失。原因是设置为0,滑动到看不见时,其实是处于中间状态,并没有完全关闭dialog。
mBehavior.setPeekHeight(height);

圆角背景:

//先设置背景为透明

dialog.getWindow().findViewById(R.id.design_bottom_sheet).setBackgroundDrawable(new ColorDrawable(Color.TRANSPARENT));

//shape

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

    <corners
        android:topLeftRadius="20dp"
        android:topRightRadius="20dp"></corners>
    <solid android:color="@color/white"></solid>

</shape>

猜你喜欢

转载自blog.csdn.net/m0_38058826/article/details/81164373
今日推荐