Android实现底部对话框BottomDialog弹出实例代码

发布时间 - 2026-01-11 00:15:47    点击率:

最近项目上需要实现一个底部对话框,要实现这样的功能其实很简单,先看代码:

private void show1() {
 Dialog bottomDialog = new Dialog(this, R.style.BottomDialog);
 View contentView = LayoutInflater.from(this).inflate(R.layout.dialog_content_normal, null);
 bottomDialog.setContentView(contentView);
 ViewGroup.LayoutParams layoutParams = contentView.getLayoutParams();
 layoutParams.width = getResources().getDisplayMetrics().widthPixels;
 contentView.setLayoutParams(layoutParams);
 bottomDialog.getWindow().setGravity(Gravity.BOTTOM);
 bottomDialog.getWindow().setWindowAnimations(R.style.BottomDialog_Animation);
 bottomDialog.show();
}

对话框的样式style:

<style name="BottomDialog" parent="@style/Base.V7.Theme.AppCompat.Light.Dialog">
 <item name="android:windowNoTitle">true</item>
 <item name="android:windowBackground">@android:color/transparent</item>
</style>

在对话框中的按钮需要MD风格的波纹效果的话,对话框的style的parent需要设定parent="@style/Base.V7.Theme.AppCompat.Light.Dialog",否则没有效果。同时将对话框所在window的标题去掉。android:windowBackground属性一定要设置成透明,否则自定义形状的对话框背景就是默认的白色了。如果不设置为透明,比如我们通常要设置的圆角对话框就没有效果。

对话框显示时从底部进入,关闭时从底部滑出。动画样式:

<style name="BottomDialog.Animation" parent="Animation.AppCompat.Dialog">
 <item name="android:windowEnterAnimation">@anim/translate_dialog_in</item>
 <item name="android:windowExitAnimation">@anim/translate_dialog_out</item>
</style>

tranlate_dialog_in.xml:

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

tranlate_dialog_out.xml:

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

实现底部对话框的原理就是修改对话框的内容布局contentView的参数,使它的宽度刚好等于屏幕的宽度,并且设置对话框所在Window的gravity属性为bottom。

需要注意的是,上面代码中需要在调用contentView.getLayoutParams()需要在setContentView方法后,否则获取到的LayoutParams为null,当然也可以自己new一个LayoutParams设置给contentView。


如果是要实现底部圆角对话框,原理也相似,只需要给contentView添加一个圆角的背景shape,并减小contentView的宽度给左右两边留一定的距离,同时给底部设置边距。

private void show2() {
 Dialog bottomDialog = new Dialog(this, R.style.BottomDialog);
 View contentView = LayoutInflater.from(this).inflate(R.layout.dialog_content_circle, null);
 bottomDialog.setContentView(contentView);
 ViewGroup.MarginLayoutParams params = (ViewGroup.MarginLayoutParams) contentView.getLayoutParams();
 params.width = getResources().getDisplayMetrics().widthPixels - DensityUtil.dp2px(this, 16f);
 params.bottomMargin = DensityUtil.dp2px(this, 8f);
 contentView.setLayoutParams(params);
 bottomDialog.getWindow().setGravity(Gravity.BOTTOM);
 bottomDialog.getWindow().setWindowAnimations(R.style.BottomDialog_Animation);
 bottomDialog.show();
}

 源码:BottomDialog_jb51.rar

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# dialog底部弹出  # android  # 底部对话框  # bottomdialog  # Android中自定义对话框(Dialog)的实例代码  # Android自定义对话框Dialog的简单实现  # 详解Android 全局弹出对话框SYSTEM_ALERT_WINDOW权限  # Android实现点击AlertDialog上按钮时不关闭对话框的方法  # 实例详解Android自定义ProgressDialog进度条对话框的实现  # Android 之BottomsheetDialogFragment仿抖音评论底部弹出对话框效果(实  # Android实现退出界面弹出提示对话框  # Android中AlertDialog各种对话框的用法实例详解  # Android仿QQ消息提示实现弹出式对话框  # Android对话框使用方法详解  # 对话框  # 圆角  # 的是  # 只需  # 就没  # 自定义  # 要给  # 设置为  # 使它  # 需要注意  # 先看  # 大家多多  # 设置成  # 其实很简单  # 滑出  # 对话框中  # BOTTOM  # BottomDialog_Animation  # show  # setGravity 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 制作电商网页,电商供应链怎么做?  Laravel如何实现API速率限制?(Rate Limiting教程)  微信小程序 wx.uploadFile无法上传解决办法  如何在橙子建站中快速调整背景颜色?  Laravel如何操作JSON类型的数据库字段?(Eloquent示例)  php做exe能调用系统命令吗_执行cmd指令实现方式【详解】  在线教育网站制作平台,山西立德教育官网?  如何在VPS电脑上快速搭建网站?  如何在腾讯云免费申请建站?  大型企业网站制作流程,做网站需要注册公司吗?  Laravel Asset编译怎么配置_Laravel Vite前端构建工具使用  如何正确选择百度移动适配建站域名?  Laravel怎么做数据加密_Laravel内置Crypt门面的加密与解密功能  Laravel怎么使用artisan命令缓存配置和视图  Laravel Blade组件怎么用_Laravel可复用视图组件的创建与使用  Win11任务栏卡死怎么办 Windows11任务栏无反应解决方法【教程】  python中快速进行多个字符替换的方法小结  网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?  JS中对数组元素进行增删改移的方法总结  企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?  Laravel路由怎么定义_Laravel核心路由系统完全入门指南  JS中页面与页面之间超链接跳转中文乱码问题的解决办法  制作企业网站建设方案,怎样建设一个公司网站?  如何用搬瓦工VPS快速搭建个人网站?  javascript中的数组方法有哪些_如何利用数组方法简化数据处理  广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?  电视网站制作tvbox接口,云海电视怎样自定义添加电视源?  如何获取免费开源的自助建站系统源码?  想要更高端的建设网站,这些原则一定要坚持!  Laravel怎么在Blade中安全地输出原始HTML内容  Java类加载基本过程详细介绍  如何在阿里云虚拟服务器快速搭建网站?  HTML透明颜色代码怎么让图片透明_给img元素加透明色的技巧【方法】  Laravel的契約(Contracts)是什么_深入理解Laravel Contracts与依赖倒置  Laravel如何创建自定义中间件?(Middleware代码示例)  Laravel怎么实现搜索高亮功能_Laravel结合Scout与Algolia全文检索【实战】  香港服务器网站生成指南:免费资源整合与高速稳定配置方案  高端企业智能建站程序:SEO优化与响应式模板定制开发  Zeus浏览器网页版官网入口 宙斯浏览器官网在线通道  长沙企业网站制作哪家好,长沙水业集团官方网站?  学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?  Laravel观察者模式如何使用_Laravel Model Observer配置  家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?  JavaScript如何操作视频_媒体API怎么控制播放  如何用好域名打造高点击率的自主建站?  高防服务器如何保障网站安全无虞?  Laravel如何使用Guzzle调用外部接口_Laravel发起HTTP请求与JSON数据解析【详解】  JavaScript Ajax实现异步通信  Laravel如何使用Laravel Vite编译前端_Laravel10以上版本前端静态资源管理【教程】  如何在 React 中条件性地遍历数组并渲染元素