Android 底部弹框实现,推荐使用 DialogFragment 来做

项目中经常需要实现底部弹出框这样的需求,实现方式有很多种,比如:Dialog、全局Activity、PopupWindow、DialogFragment都可以达到目的。经过很多实践之后,发现使用 DialogFragment 是最优的。

DialogFragment 优点

  • 它本身是一个 Fragment ,所以在这里进行网络请求等操作肯定比上面说的其他几种要好。
  • DialogFragment 点击外部区域消失这些问题没有 PopupWindow 那么麻烦,自带就有这样的效果。
  • 支持灵活自定义布局,实现不同的样式,和 Activity 关联程度低

DialogFragment 设置常见的注意点

以一个具体代码为例,需要注意的地方都加了注释。

public class BottomDialogFr extends DialogFragment {

    private View frView;
    private Window window;

    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        // 去掉默认的标题
        getDialog().requestWindowFeature(Window.FEATURE_NO_TITLE);
        frView = inflater.inflate(R.layout.dialog_fr_bottom, null);
        return frView;
    }

    @Override
    public void onStart() {
        super.onStart();
        // 下面这些设置必须在此方法(onStart())中才有效

        window = getDialog().getWindow();
        // 如果不设置这句代码, 那么弹框就会与四边都有一定的距离
        window.setBackgroundDrawableResource(android.R.color.transparent);
        // 设置动画
        window.setWindowAnimations(R.style.bottomDialog);

        WindowManager.LayoutParams params = window.getAttributes();
        params.gravity = Gravity.BOTTOM;
        // 如果不设置宽度,那么即使你在布局中设置宽度为 match_parent 也不会起作用
        params.width = getResources().getDisplayMetrics().widthPixels;
        window.setAttributes(params);
    }

}

如果其内部是一个列表,那么高度可在 onStart() 方法中设置宽度的地方进行设置,布局中设置是无效的。

调用其显示的代码

BottomDialogFr bottomDialogFr = new BottomDialogFr();
bottomDialogFr.show(getSupportFragmentManager(), "DF");

效果图
dialogFragment

再贴一下动画的代码
Style

<!--底部弹框动画-->
    <style name="bottomDialog">
        <item name="android:windowEnterAnimation">@anim/dialog_fr_in</item>
        <item name="android:windowExitAnimation">@anim/dialog_fr_out</item>
    </style>

进入动画

<?xml version="1.0" encoding="utf-8"?>
<translate xmlns:android="http://schemas.android.com/apk/res/android"
    android:duration="300"
    android:fromYDelta="100%"
    android:toYDelta="0">

</translate>

退出动画

<?xml version="1.0" encoding="utf-8"?>
<translate xmlns:android="http://schemas.android.com/apk/res/android"
    android:duration="300"
    android:fromYDelta="0"
    android:toYDelta="100%">

</translate>

到此,核心代码就完了。


Android 技术分享平台
code小生

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

code小生

有头像,我们容易成为朋友

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值