用Dialog实现底部弹窗

本文介绍了如何使用Dialog在Android应用中实现从底部弹出的效果。通过设置对话框位置、定义动画样式,并重写触摸事件处理,可以创建符合需求的底部弹窗效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

有时要实现各种各样的弹窗,譬如选择支付方式的时候,很多APP就会选择由底部弹上来的。如图:

这里写图片描述

下面是Dialog的实现:

public class ChoosePayStatusDialog extends Dialog {

    private LinearLayout aliPayLly;
    private LinearLayout weixinPayLly;

    public ChoosePayStatusDialog(@NonNull Context context) {
        super(context, R.style.BottomDialog);//关键代码
        setContentView(R.layout.dialog_choose_pay);//关键代码
        setCancelable(true);//关键代码
        setCanceledOnTouchOutside(true);//关键代码
        getWindow().setGravity(Gravity.BOTTOM);//关键代码
        getWindow().setLayout(WindowManager.LayoutParams.MATCH_PARENT, WindowManager.LayoutParams.WRAP_CONTENT);

        aliPayLly= (LinearLayout) findViewById(R.id.aliPayLly);
        weixinPayLly= (LinearLayout) findViewById(R.id.weixinPayLly);
        aliPayLly.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                EventBus.getDefault().post(new ChoosePayBean(2));
                dismiss();

            }
        });

        weixinPayLly.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                EventBus.getDefault().post(new ChoosePayBean(1));
                dismiss();
            }
        });

    }

    @Override
    public boolean onTouchEvent(MotionEvent event) {
        /* 触摸外部弹窗 */
        if (isOutOfBounds(getContext(), event)) {
            EventBus.getDefault().post(new ChoosePayBean());
            dismiss();
        }
        return super.onTouchEvent(event);
    }


    private boolean isOutOfBounds(Context context, MotionEvent event) {
        final int x = (int) event.getX();
        final int y = (int) event.getY();
        final int slop = ViewConfiguration.get(context).getScaledWindowTouchSlop();
        final View decorView = getWindow().getDecorView();
        return (x < -slop) || (y < -slop) || (x > (decorView.getWidth() + slop))
                || (y > (decorView.getHeight() + slop));
    }
}

以上代码中:

getWindow().setGravity(Gravity.BOTTOM);

设置对话框的位置,这里设置成底部,也可以设置成Gravity.CENTER,根据需求而定。

super(context, R.style.BottomDialog);

BottomDialog样式文件代码如下:

<style name="BottomDialog">
        <item name="android:windowIsTranslucent">true</item>
        <item name="android:windowBackground">@android:color/transparent</item>
        <item name="android:windowContentOverlay">@null</item>
        <item name="android:windowNoTitle">true</item>
        <item name="android:backgroundDimEnabled">true</item>
        <item name="android:windowIsFloating">false</item>
        <item name="android:windowAnimationStyle">@style/DialogAnimation</item>
        <item name="android:gravity">bottom</item>
    </style>

@style/DialogAnimation中是定义对话框出现与消失的动画,文件内容如下:

<style name="DialogAnimation">
        <item name="android:windowEnterAnimation">@anim/slide_up</item>
        <item name="android:windowExitAnimation">@anim/slide_down</item>
    </style>

@anim/slide_up内容如下:

<set xmlns:android="http://schemas.android.com/apk/res/android"
    android:fillAfter="true"
    android:fillBefore="true"
    android:fillEnabled="true"
    android:interpolator="@anim/anim_interpolator"
    android:shareInterpolator="true"
    android:zAdjustment="top">
    <translate
        android:duration="500"
        android:fromYDelta="100%p"
        android:toYDelta="0%p" />
</set>

@anim/slide_down内容如下:

<set xmlns:android="http://schemas.android.com/apk/res/android"
    android:interpolator="@android:anim/decelerate_interpolator"
    android:shareInterpolator="true">
    <translate
        android:duration="500"
        android:fromYDelta="0.0%p"
        android:toYDelta="100.0%p" />
</set>

重写onTouchEvent方法和isOutOfBounds是为了监听点击对话框阴影部分,可以根据实际需求来定,关于这部分的博客地址为:《关于给Dialog设置setCanceledOnTouchOutside(true)后如何监听Dialog消失》

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值